QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#417204#4424. Babushka and her pierogiDiuAC ✓482ms10060kbC++141.2kb2024-05-22 16:09:572024-05-22 16:09:57

Judging History

你现在查看的是最新测评结果

  • [2024-05-22 16:09:57]
  • 评测
  • 测评结果:AC
  • 用时:482ms
  • 内存:10060kb
  • [2024-05-22 16:09:57]
  • 提交

answer

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=2e5+10;
const ll Inf=1e18;
int T,n,p[N],ip[N],q[N],val[N],C;
int a[N],b[N];
struct node{int x,y;};
vector<node> ga;
ll ans;
void chg(int x,int y){
	ans+=C+abs(val[x]-val[y]);
	ga.push_back({ip[x],ip[y]});
	swap(ip[x],ip[y]);
	swap(a[x],a[y]);
	swap(b[a[x]],b[a[y]]);
}
bool chk(int x,int y){
	if(x>y)swap(x,y);
	if(x==y)return 0;
	return a[x]>=y&&a[y]<=x;
}
void split(int x){
	int y=b[x];
	for(int i=x,j=b[y];;i=a[i],j=b[j]){
		if(chk(y,i))return chg(y,i);
		if(chk(y,j))return chg(y,j);
	}
}
signed main(){
	scanf("%d",&T);
	for(;T--;){
		scanf("%d%d",&n,&C);
		for(int i=1;i<=n;i++)scanf("%d%d",&p[i],&q[i]),val[i]=p[i];
		sort(val+1,val+n+1);
		for(int i=1;i<=n;i++){
			p[i]=lower_bound(val+1,val+n+1,p[i])-val;
			q[i]=lower_bound(val+1,val+n+1,q[i])-val;
		}
		for(int i=1;i<=n;i++)ip[p[i]]=i;
		for(int i=1;i<=n;i++)a[i]=q[ip[i]];
		for(int i=1;i<=n;i++)b[a[i]]=i;
		ans=0;ga.clear();
		for(int i=1;i<=n;i++)while(a[i]!=i)split(i);
		printf("%lld %d\n",ans,(int)ga.size());
		for(node t:ga)printf("%d %d\n",t.x,t.y);
	}
}
/*
2
6 135
12 53
24 12
43 24
13 43
20 13
53 20
*/

详细

Test #1:

score: 100
Accepted
time: 463ms
memory: 10060kb

input:

1000
3220 272696332
766498233 728308608
664527309 611122504
769309894 72297979
848647465 356897274
645591201 895123264
165094010 486891491
31233252 552012226
84149600 93558181
569880970 31233252
925517631 900673333
254671525 65782954
360356809 123019566
435505772 128102614
595657911 878072081
138392...

output:

1425165727822 3210
866 2835
3026 1533
3026 907
3026 854
3026 733
2507 1361
2801 1624
2801 164
567 1819
567 1367
2189 1389
2189 1814
881 37
2329 2760
2243 843
1225 355
1225 1177
1225 3077
1225 621
1225 2382
2605 732
2605 1290
2605 1446
2605 1427
3073 1559
3176 642
3176 502
1969 346
1969 2122
1749 262...

result:

ok ac (1000 test cases)

Test #2:

score: 0
Accepted
time: 482ms
memory: 9992kb

input:

5
200000 42944121
574814309 67495230
53276728 150326725
864637686 234510550
10036337 414740
506850796 483988482
236014120 843625769
809762843 19603788
507104953 885632626
866590783 119176179
188251555 598788216
652874956 535446529
193164017 235823046
925533029 523948529
50446166 36338992
380571133 6...

output:

43086875784557 199984
176783 167123
29816 151066
149462 156960
149462 199103
149462 168834
47437 19518
47437 121747
77177 164375
77177 82430
77177 32697
77177 71557
77177 129942
55856 54145
491 193283
491 45134
491 27057
491 46967
9721 142843
54648 141633
195822 121873
93825 172619
93825 3986
93825 ...

result:

ok ac (5 test cases)

Test #3:

score: 0
Accepted
time: 459ms
memory: 10024kb

input:

5
200000 22877235
36648700 36642254
935593015 935591420
912067011 912055984
229315170 229314259
83126790 83123673
949986358 949980907
563637725 563627158
131644066 131631233
202694678 202691574
747915499 747915206
433149695 433125141
466955691 466945175
770435427 770425839
333350582 333349002
794680...

output:

4576424117766 199999
155223 13670
169318 13670
122272 13670
186701 13670
25846 13670
179211 13670
193487 13670
101581 13670
66607 13670
103962 13670
172890 13670
163342 13670
74383 13670
19151 13670
117913 13670
6901 13670
126267 13670
43459 13670
87097 13670
15151 13670
59717 13670
194422 13670
865...

result:

ok ac (5 test cases)

Extra Test:

score: 0
Extra Test Passed