0%

思路讲解

image

AC代码

AC
https://www.spoj.com/status/ns=35103793

心路历程(WA,TLE,MLE……)

思路讲解

AC代码

https://www.codechef.com/viewsolution/1210385010

心路历程(WA,TLE,MLE……)

思路讲解

赛时AC的。

1
2
3
4
5
6
        if(cnta>=A && cntb<B) {
// ans+=(cnta-A+1)
ans+=(*posa.find_by_order(cnta-A)-i+1);

}

// ans+=(cnta-A+1)
hack数据:

1
2
3
4
7 2 3
aabbaba


1
7

AC代码

https://atcoder.jp/contests/abc430/submissions/70626068

心路历程(WA,TLE,MLE……)

题目大意

有一个周长为 MM 的池塘,岸边有一个小屋和 NN 个人。定义地点 xx 为从小屋顺时针走 xx 距离的位置( 0x<M0 \leq x < M )。第 ii 个人站在地点 AiA_i 处,多个人可能站在同一位置。

对于 i=0,1,,M1i = 0, 1, \ldots, M-1 ,定义 XiX_i

  1. 高橋君从地点 (i+0.5)(i+0.5) 出发,开始顺时针移动

  2. 他会一直移动,直到遇到的人数总计达到 CC 人或更多时停止

  3. XiX_i 是他遇到的总人数(如果停止位置有多人,全部计入,因此 XiX_i 可能大于 CC

求所有 XiX_i 的总和: i=0M1Xi\sum_{i=0}^{M-1} X_i

输入格式:

  • 第一行: NN MM CC

  • 第二行: A1A_1 A2A_2 \ldots ANA_N

输出格式:

  • 一个整数,表示 XiX_i 的总和

思路讲解

AC代码

https://atcoder.jp/contests/abc429/submissions/70464977

心路历程(WA,TLE,MLE……)

思路讲解

交换一定使得逆序对数量奇偶性变化,循环移动一格可以看作交换len-1次

(长度为len的)向左(向右)循环移动一次可以看作交换len-1次

第 49 届 ICPC区域赛沈阳站——D. Dot Product Game

1
2
3
4
5
6
7
8
9
10
11
FOR(i, 1, N - 1) {
char ch;
ll l, r, d;
cin >> ch >> l >> r >> d;
ll len = r - l + 1;
// 向左循环移动一个可以看作交换len-1次,向左循环移动d次,就是交换d*(len-1)次
if (d != 0)
inva += (len-1)*d;
out();
}

然后如何比较快速的求出一个数组中的这个逆序对的奇偶性呢?其实也不难。

众所周知,排列成环,成的环,在环上向左循环移动一次以后就复位了。那么如果说有一个环,(以下说相等,是默认是奇偶性相等),那么逆序对就是N-1,有两个环,逆序对就是N-2。因此只需要知道环的数量即可,会比这个直接用这个树状数组求好写一点。

image

image

AC代码

https://qoj.ac/submission/1658154

心路历程(WA,TLE,MLE……)