社区讨论
关于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 条回复,欢迎继续交流。
正在加载回复...