Sort it Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 1940 Accepted Submission(s): 1390 Problem Description You want to processe a sequence of n distinct integers by swapping two adjacent sequence elements until the sequence is sorted in ascending order. Then how many times it need. For example, 1 2 3 5 4, we only need one operation : swap 5 and 4. Input The input consists of a number of test cases. Each case consists of two lines: the first line contains a positive integer n (n <= 1000); the next line contains a permutation of the n integers from 1 to n. Output For each case, output the minimum times need to sort it in ascending order on a single line. Sample Input 3 1 2 3 4 4 3 2 1 Sample Output 0 6 Author WhereIsHeroFrom Source ZJFC 2009-3 Programming Contest Recommend yifenfei 題意是給你一個序列,問你最少交換多少次可以使整個序列單調上升。 數據只有1000,直接n^2可做,但是有一種更為精妙的方法——樹狀數組 0Ms 我們先初始化整個序列為0,然後每輸入一個數x,就在x位置將0換成1,此時求該位置的sum,就是比x小的數字數目,顯然i - sum就是是這個數字要交換的次數。
#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstring>
using namespace std;
int a[1010], c[1010] , n;
int lowbit(int x)
{
return x & (-x);
}
int sum(int x)
{
int sum = 0;
while(x > 0)
{
sum += c[x];
x -= lowbit(x);
}
return sum;
}
void update(int x , int num)
{
while(x <= n)
{
c[x] += num;
x += lowbit(x);
}
}
int main()
{
while(~scanf("%d" , &n))
{
memset(a , 0 , sizeof(a));
memset(c , 0 , sizeof(c));
int ans = 0;
int x;
for(int i = 1 ; i <= n ; i++)
{
scanf("%d" , &x);
update(x , 1);
ans += i - sum(x);
}
printf("%d\n" , ans);
}
return 0;
}