#include "kanapka.h"
#include "message.h"
#include <bits/stdc++.h>
using namespace std;
using i64 = long long;
struct info {
i64 lans, rans, sum, ans;
void append(info right){
ans = min(min(ans, right.ans), rans + right.lans);
lans = min(lans, sum + right.lans);
rans = min(right.rans, right.sum + rans);
sum += right.sum;
}
void append(i64 number){
i64 value = min(number, 0LL);
ans = min(ans, rans + value);
lans = min(lans, sum + value);
rans = min(value, number + rans);
sum += number;
}
} result;
int nodes, current_node, n, L, R;
int main(){
nodes = NumberOfNodes();
current_node = MyNodeId();
n = GetN();
L = current_node * 1.0 / nodes * n;
R = (current_node + 1) * 1.0 / nodes * n;
for (int x = L; x < R; ++x) result.append(GetTaste(x));
if (current_node == 0) {
for (int x = 1; x < nodes; ++x) {
Receive(x);
info get;
get.lans = GetLL(x), get.rans = GetLL(x), get.sum = GetLL(x), get.ans = GetLL(x);
result.append(get);
}
cout << result.sum - result.ans << endl;
} else {
PutLL(0, result.lans), PutLL(0, result.rans), PutLL(0, result.sum), PutLL(0, result.ans);
Send(0);
}
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 | #include "kanapka.h" #include "message.h" #include <bits/stdc++.h> using namespace std; using i64 = long long; struct info { i64 lans, rans, sum, ans; void append(info right){ ans = min(min(ans, right.ans), rans + right.lans); lans = min(lans, sum + right.lans); rans = min(right.rans, right.sum + rans); sum += right.sum; } void append(i64 number){ i64 value = min(number, 0LL); ans = min(ans, rans + value); lans = min(lans, sum + value); rans = min(value, number + rans); sum += number; } } result; int nodes, current_node, n, L, R; int main(){ nodes = NumberOfNodes(); current_node = MyNodeId(); n = GetN(); L = current_node * 1.0 / nodes * n; R = (current_node + 1) * 1.0 / nodes * n; for (int x = L; x < R; ++x) result.append(GetTaste(x)); if (current_node == 0) { for (int x = 1; x < nodes; ++x) { Receive(x); info get; get.lans = GetLL(x), get.rans = GetLL(x), get.sum = GetLL(x), get.ans = GetLL(x); result.append(get); } cout << result.sum - result.ans << endl; } else { PutLL(0, result.lans), PutLL(0, result.rans), PutLL(0, result.sum), PutLL(0, result.ans); Send(0); } } |
English