hiho week 277 register

Ended

Participants:49

Verdict:Accepted
Score:100 / 100
Submitted:2019-10-22 15:50:36

Lang:G++

Edit
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
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
typedef long long LL;
const int N =1e5+7;
int arr[N], tmp[N];
LL mergesort(int l, int r){
    if(l >= r) return 0;
    int mid = l + r >> 1;
    LL res = mergesort(l, mid) + mergesort(mid+1, r);
    int k = 0, i = l, j = mid + 1;
    while(i <= mid && j <= r){
        if(arr[i] <= arr[j]) tmp[k++] = arr[i++];
        else{
            tmp[k++] = arr[j++];
            res += mid - i + 1;
        }
    }
    while(i <= mid) tmp[k++] = arr[i++];
    while(j <= r) tmp[k++] = arr[j++];
    
    for(int i = l, j = 0; i <= r; i++, j++){
        arr[i] = tmp[j];
    }
    return res;
}
int main(){
    int n;
    scanf("%d", &n);
    for(int i = 0;i < n; i++){
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX