#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 条评论

  • 1