社区讨论

关于o2

P4289[HAOI2008] 移动玩具参与者 2已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
3 条
当前快照
1 份
快照标识符
@lobf92su
此快照首次捕获于
2023/10/29 20:02
2 年前
此快照最后确认于
2023/11/04 01:35
2 年前
查看原帖
一份代码,没开O2挂成了0分,全RE。开了之后就A了
CPP
#include<bits/stdc++.h>
using namespace std;
int dp[100005],vis[100005];
int pii[16];
queue<int> q;
char gc(){
	char ch=getchar();
	while(ch!='0'&&ch!='1') ch=getchar();
	return ch;
}
int frm,to;
main(){
	pii[0]=1;
	for(int i=1;i<=16;i++) pii[i]=pii[i-1]<<1;
	for(int i=1,u;i<=16;i++) u=gc()-'0',frm+=u*pii[i-1];
	q.push(frm);
	for(int i=1,u;i<=16;i++) u=gc()-'0',to+=u*pii[i-1];
	while(!q.empty()){
		int x=q.front();q.pop();
		if(x==to){
			printf("%d",dp[x]);
			return 0;
		}
		for(int i=1;i<=16;i++){
			if(!(x&pii[i-1])) continue;
			for(int j=1;j<=16;j++){
				if(x&pii[j-1]) continue;
				if(!vis[x-pii[i-1]+pii[j-1]]&&(j==i+4||j==i-4||(j==i-1&&i%4!=1)||(j==i+1&&i%4))){
					q.push(x-pii[i-1]+pii[j-1]);
					dp[x-pii[i-1]+pii[j-1]]=dp[x]+1;
					vis[x-pii[i-1]+pii[j-1]]=1;
				}
			}
		}
	}
} 

回复

3 条回复,欢迎继续交流。

正在加载回复...