#ifdef _MSC_VER
#ifndef __GNUC__
#pragma warning(disable: 4996)
#endif
#define main main0
#endif
#include "message.h"
#include "teatr.h"
#include <iostream>
using namespace std;
int wzrost[1000001];
int main() {
ios_base::sync_with_stdio(0);
//cin.tie(NULL);
int numberOfNodes = NumberOfNodes();
int myNodeId = MyNodeId();
int N = GetN();
int minRzad = N * myNodeId / numberOfNodes;
int maxRzad = N * (myNodeId + 1) / numberOfNodes;
long long wynik = 0;
int i = 0;
for(int j = minRzad; j < maxRzad; ++j) {
wzrost[i] = GetElement(j);
for(int k = i++; k > 0; --k) {
if(wzrost[k-1] <= wzrost[k])
break;
swap(wzrost[k], wzrost[k-1]);
++wynik;
}
}
if(myNodeId < N-1) {
int next = myNodeId + 1;
Receive(next);
wynik += GetLL(next);
int ile = GetInt(next);
for(int j = 0; j < ile; ++j) {
wzrost[i] = GetInt(next);
// int m = GetInt(next);
for(int k = i++; k > 0; --k) {
if(wzrost[k-1] <= wzrost[k])
break;
swap(wzrost[k], wzrost[k-1]);
++wynik;
}
}
}
if(myNodeId > 0) {
int prev = myNodeId - 1;
// int m = 0;
PutLL(prev, wynik);
PutInt(prev, i);
for(int j = 0; j < i; ++j)
PutInt(prev, wzrost[j]);
// PutInt(prev, m);
Send(prev);
}
if(myNodeId == 0)
cout << wynik << endl;
return 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 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 | #ifdef _MSC_VER #ifndef __GNUC__ #pragma warning(disable: 4996) #endif #define main main0 #endif #include "message.h" #include "teatr.h" #include <iostream> using namespace std; int wzrost[1000001]; int main() { ios_base::sync_with_stdio(0); //cin.tie(NULL); int numberOfNodes = NumberOfNodes(); int myNodeId = MyNodeId(); int N = GetN(); int minRzad = N * myNodeId / numberOfNodes; int maxRzad = N * (myNodeId + 1) / numberOfNodes; long long wynik = 0; int i = 0; for(int j = minRzad; j < maxRzad; ++j) { wzrost[i] = GetElement(j); for(int k = i++; k > 0; --k) { if(wzrost[k-1] <= wzrost[k]) break; swap(wzrost[k], wzrost[k-1]); ++wynik; } } if(myNodeId < N-1) { int next = myNodeId + 1; Receive(next); wynik += GetLL(next); int ile = GetInt(next); for(int j = 0; j < ile; ++j) { wzrost[i] = GetInt(next); // int m = GetInt(next); for(int k = i++; k > 0; --k) { if(wzrost[k-1] <= wzrost[k]) break; swap(wzrost[k], wzrost[k-1]); ++wynik; } } } if(myNodeId > 0) { int prev = myNodeId - 1; // int m = 0; PutLL(prev, wynik); PutInt(prev, i); for(int j = 0; j < i; ++j) PutInt(prev, wzrost[j]); // PutInt(prev, m); Send(prev); } if(myNodeId == 0) cout << wynik << endl; return 0; } |
English