QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#655980 | #9478. Shift Puzzle | ucup-team4938# | WA | 0ms | 3984kb | C++14 | 4.4kb | 2024-10-19 10:40:01 | 2024-10-19 10:40:02 |
Judging History
answer
#include<bits/stdc++.h>
#define int long long
#define mod 998244353ll
#define pii pair<int,int>
#define fi first
#define se second
#define mems(x,y) memset(x,y,sizeof(x))
#define pb push_back
#define db double
using namespace std;
const int maxn=85;
const int inf=1e18;
inline int read(){
int x=0,f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+(ch-48);ch=getchar();}
return x*f;
}
bool Mbe;
int n;
char s[maxn][maxn],t[maxn][maxn];
int a[maxn][maxn],b[maxn][maxn],c[maxn][maxn];
int tmp[maxn];
vector<pii> ans,res;
int pre[maxn],nxt[maxn];
void work(){
n=read();
for(int i=1;i<=n;i++)pre[i]=i-1,nxt[i]=i+1;
pre[1]=n,nxt[n]=1;
for(int i=1;i<=n;i++)scanf("%s",s[i]+1);
for(int i=1;i<=n;i++)scanf("%s",t[i]+1);
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)a[i][j]=s[i][j]=='.';
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)b[i][j]=t[i][j]=='.';
}
int num=0;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)num+=a[i][j];
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)num-=b[i][j];
}
if(num){
puts("No");
return ;
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)num+=a[i][j];
}
if(num<n){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)a[i][j]=1-a[i][j],b[i][j]=1-b[i][j];
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++)c[i][j]=a[i][j];
}
// for(int i=1;i<=n;i++){
// for(int j=1;j<=n;j++)cout<<b[i][j];cout<<"\n";
// }
for(int i=1;i<=n;i++)if(!b[i][n]){
bool fl=0;
for(int j=1;j<=n;j++){
for(int k=1;k<n;k++)if(b[j][k]){
int u=j,v=k;
while(u!=i){
for(int l=1;l<=n;l++)tmp[pre[l]]=b[l][v];
for(int l=1;l<=n;l++)b[l][v]=tmp[l];
res.pb({2,v});
u=pre[u];
}
while(v!=n){
for(int l=1;l<=n;l++)tmp[pre[l]]=b[u][l];
for(int l=1;l<=n;l++)b[u][l]=tmp[l];
res.pb({1,u});
v=pre[v];
}
fl=1;break;
}
if(fl)break;
}
}
// for(int i=1;i<=n;i++){
// for(int j=1;j<=n;j++)cout<<b[i][j];cout<<"\n";
// }
reverse(res.begin(),res.end());
// for(auto[op,x]:res){
// if(op==1){
// for(int l=1;l<=n;l++)tmp[nxt[l]]=b[x][l];
// for(int l=1;l<=n;l++)b[x][l]=tmp[l];
// }else{
// for(int l=1;l<=n;l++)tmp[nxt[l]]=b[l][x];
// for(int l=1;l<=n;l++)b[l][x]=tmp[l];
// }
// }
// for(int i=1;i<=n;i++){
// for(int j=1;j<=n;j++)cout<<a[i][j];cout<<"\n";
// }
// for(int i=1;i<=n;i++){
// for(int j=1;j<=n;j++)cout<<b[i][j];cout<<"\n";
// }
for(int i=1;i<=n;i++){
for(int j=1;j<n;j++)if(a[i][j]!=b[i][j]){
bool fl=0;
for(int k=n;k>=i;k--){
for(int l=n;l>=(k==i?j+1:1);l--)if(a[k][l]==b[i][j]){
int u=k,v=l;
while(v!=n){
for(int l=1;l<=n;l++)tmp[nxt[l]]=a[u][l];
for(int l=1;l<=n;l++)a[u][l]=tmp[l];
ans.pb({1,u});
v=nxt[v];
}
if(i==k){
for(int l=1;l<=n;l++)tmp[nxt[l]]=a[l][v];
for(int l=1;l<=n;l++)a[l][v]=tmp[l];
ans.pb({2,v});
u=nxt[u];
}
v=j;
while(v!=n){
for(int l=1;l<=n;l++)tmp[nxt[l]]=a[i][l];
for(int l=1;l<=n;l++)a[i][l]=tmp[l];
ans.pb({1,i});
v=nxt[v];
}
// cout<<u<<" "<<v<<"\n";
v=n;
while(u!=i){
for(int l=1;l<=n;l++)tmp[nxt[l]]=a[l][v];
for(int l=1;l<=n;l++)a[l][v]=tmp[l];
ans.pb({2,v});
u=nxt[u];
}
while(v!=j){
for(int l=1;l<=n;l++)tmp[nxt[l]]=a[u][l];
for(int l=1;l<=n;l++)a[u][l]=tmp[l];
ans.pb({1,u});
v=nxt[v];
}
// cout<<i<<" "<<j<<" "<<k<<" "<<l<<"\n";
// for(int ii=1;ii<=n;ii++){
// for(int jj=1;jj<=n;jj++)cout<<a[ii][jj];cout<<"\n";
// }
fl=1;break;
}
if(fl)break;
}
}
}
for(pii p:res)ans.pb(p);
puts("Yes");printf("%lld\n",(int)ans.size());
for(auto[fl,x]:ans)printf("%lld %lld\n",fl,x);
// for(auto[op,x]:ans){
// if(op==1){
// for(int l=1;l<=n;l++)tmp[nxt[l]]=c[x][l];
// for(int l=1;l<=n;l++)c[x][l]=tmp[l];
// }else{
// for(int l=1;l<=n;l++)tmp[nxt[l]]=c[l][x];
// for(int l=1;l<=n;l++)c[l][x]=tmp[l];
// }
// }
// for(int i=1;i<=n;i++){
// for(int j=1;j<=n;j++)cout<<c[i][j];
// cout<<"\n";
// }
}
// \
444
bool Med;
int T;
signed main(){
// freopen(".in","r",stdin);
// freopen(".out","w",stdout);
// ios::sync_with_stdio(0);
// cin.tie(0);cout.tie(0);
// cerr<<(&Mbe-&Med)/1048576.0<<" MB\n";
T=1;
while(T--)work();
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3936kb
input:
3 .#. #.# .#. #.# ... #.#
output:
Yes 16 1 3 1 1 1 1 2 3 1 1 2 3 1 3 2 3 2 3 1 3 1 3 1 3 2 1 2 1 1 1 1 1
result:
ok AC
Test #2:
score: 0
Accepted
time: 0ms
memory: 3856kb
input:
3 .#. #.# .#. .#. #.# .#.
output:
Yes 26 1 2 1 2 2 3 2 3 1 2 1 3 1 2 2 3 2 3 1 2 1 2 2 3 1 3 1 3 2 3 2 3 1 3 2 3 1 3 2 3 2 3 1 3 1 3 1 2 2 1 2 1
result:
ok AC
Test #3:
score: 0
Accepted
time: 0ms
memory: 3872kb
input:
13 ............. ....#####.... ......#...... ......#...... ......#...... ......#...... ............. ....#...#.... ....#...#.... ....#...#.... ....#...#.... .....###..... ............. ....####..... ....#...#.... ....####..... ....#........ ....#........ ............. .....###..... ....#...#.... ......
output:
No
result:
ok AC
Test #4:
score: 0
Accepted
time: 0ms
memory: 3676kb
input:
3 #.# #.# ### #.# .#. ###
output:
No
result:
ok AC
Test #5:
score: 0
Accepted
time: 0ms
memory: 3760kb
input:
4 .#.. .#.. .... ...# .... ..#. #... ....
output:
No
result:
ok AC
Test #6:
score: 0
Accepted
time: 0ms
memory: 3860kb
input:
4 .... .... .... .#.. ..## ##.# #### ..##
output:
No
result:
ok AC
Test #7:
score: 0
Accepted
time: 0ms
memory: 3984kb
input:
2 .. .. .. ..
output:
Yes 0
result:
ok AC
Test #8:
score: -100
Wrong Answer
time: 0ms
memory: 3936kb
input:
3 .## ##. .#. ##. ..# .##
output:
Yes 11 1 3 2 3 1 3 1 3 2 3 2 3 1 3 1 3 2 1 2 1 1 2
result:
wrong answer WA S is not T