- C++
题目求调,0分WA
- @ 2025-7-19 18:20:18

#include<iostream>
using namespace std;
int h[37][3],b[26];
int dx[]={0,-1,0,1};
int dy[]={-1,0,1,0};
bool a[10][10];
int tail=1,t=0,k;
int main(){
for(int i=0;i<5;i++){
for(int j=0;j<5;j++)
cin>>a[i][j];
}
h[1][1]=0,h[1][2]=0;
a[0][0]=1;
do{
t++;
bool find=false;
for(int i=0;i<4;i++){
int xx=h[t][1]+dx[i];
int yy=h[t][2]+dy[i];
if(xx>=0&&xx<5&&yy>=0&&yy<5&&a[xx][yy]==0){
a[xx][yy]=1;
tail++;
h[tail][0]=t;
h[tail][1]=xx;
h[tail][2]=yy;
if(xx==4&&yy==4) {
find=true;
break;
}
}
}
if(find) break;
}while(t<tail);
while(tail>=1){
b[++k]=tail;
tail=h[tail][0];
}
for(int i=k;i>=1;i--){
cout<<"("<<h[b[i]][1]<<","<<h[b[i]][2]<<")\n";
}
return 0;
}
#include<bits/stdc++.h>
#define int long long
using namespace std;
int a[105][105],b[105][105];
int dx[]={0,-1,0,1};
int dy[]={-1,0,1,0};
int tx,ty,tot;
void print(int a,int aa){
if(a==0&&aa==0){
cout<<"(0,0)"<<endl;
return ;
}
print(b[a][aa]/5,b[a][aa]%5);
cout<<"("<<a<<","<<aa<<")"<<endl;
}
void dfs(int a[][105],int x,int y){
if(a[x][y]==999) return ;
for(int i=0;i<4;i++){
int xx=x+dx[i];
int yy=y+dy[i];
if(a[xx][yy]!=999&&0<=xx&&xx<=4&&0<=yy&&ty<=4){
tot=a[x][y]+1;
if(tot<a[xx][yy]||a[xx][yy]==0){
a[xx][yy]=tot;
b[xx][yy]=x*5+y;
dfs(a,xx,yy);
}
}
}
return ;
}
signed main(){
for(int i=0;i<5;i++){
for(int j=0;j<5;j++){
cin>>a[i][j];
if(a[i][j]==1)a[i][j]=999;
}
}
dfs(a,0,0);
print(4,4);
return 0;
}
求调
1 条评论
-
winterini LV 7 @ 2025-7-19 20:04:26边界判断错了 && 改成 ||
👍 1❤️ 1
- 1