#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; } |