题目地址:http://ac.jobdu.com/problem.php?pid=1348
4 7 5 6 4
5
#include <stdio.h> long long cnt; void Merge (int data[], int start, int mid, int end){ int new_data[100000]; int i = start; int j = mid + 1; int k = start; while (i <= mid && j <= end){ if (data[i] > data[j]){ new_data[k] = data[i]; ++i; ++k; cnt += (end - j + 1); } else{ new_data[k] = data[j]; ++j; ++k; } } while (i <= mid){ new_data[k] = data[i]; ++i; ++k; } while (j <= end){ new_data[k] = data[j]; ++j; ++k; } while (start <= end){ data[start] = new_data[start]; ++start; } } void MergeSort (int data[], int start, int end){ int mid; if (start < end){ mid = (start + end) >> 1; MergeSort (data, start, mid); MergeSort (data, mid + 1, end); Merge (data, start, mid, end); } } int main(void){ int n; int data[100000]; int i; while (scanf ("%d", &n) != EOF){ for (i=0; i<n; ++i) scanf ("%d", &data[i]); cnt = 0; MergeSort (data, 0, n - 1); printf ("%lld\n", cnt); } return 0; }
原文:http://blog.csdn.net/jdplus/article/details/19325399