年前最后一次2022.1.28_RP++

T1同昨(我看到题目就粘上昨天的代码,结果题还没发我就A了hhhhhh)
T2一开始想用深搜,结果T掉了。。。只好改广搜,就挺令人头大

点击查看宽广对比
#include<bits/stdc++.h>
using namespace std;
int sum,n;
int a[50][50];
bool vis[50][50];
void dfs(int x,int y) {
	if(x>n+1||y>n+1||x<0||y<0)return;
	if(a[x][y])return;
	a[x][y]=2;
	vis[x][y]=1;
	dfs(x+1,y);
	dfs(x,y+1);
	dfs(x-1,y);
	dfs(x,y-1);
	return;
}
int main() {
	scanf("%d",&n);
	for(int i=1; i<=n; i++) {
		for(int j=1; j<=n; j++) {
			scanf("%d",&a[i][j]);
			if(a[i][j]==1)sum++;
		}
	}
	dfs(0,0);//横纵坐标
	for(int i=1; i<=n; i++) {
		for(int j=1; j<=n; j++) {
			if(a[i][j]==1) printf("1 ");
			if(a[i][j]==2) printf("0 ");
			if(a[i][j]==0) printf("2 ");
		}
		printf("\n");
	}
	return 0;
}
点击查看宽广对比
#include<bits/stdc++.h>
using namespace std;
char a[1010][1010];
int sum,mi;
int gox[4]= {1,-1,0,0},goy[4]= {0,0,1,-1},h[1000001][4];
int n,qx,qy,zx,zy;
int bfs(int x,int y) {
	int tail=1,head=0,xx,yy;
	h[1][1]=x;
	h[1][2]=y;
	h[1][3]=0;
	while(tail>head) {
		head++;
		for(int i=0; i<4; i++) {
			xx=h[head][1]+gox[i];
			yy=h[head][2]+goy[i];
			if(xx==zx&&yy==zy) {
				return h[head][3]+1;
			}
			if(xx>=1&&yy>=1&&xx<=n&&yy<=n&&a[xx][yy]=='0') {
				tail++;
				a[xx][yy]='1';
				h[tail][1]=xx;
				h[tail][2]=yy;
				h[tail][3]=h[head][3]+1;
			}
		}
	}
}
int main() {
	cin>>n;
	for(int i=1; i<=n; i++)
		for(int j=1; j<=n; j++)
			cin>>a[i][j];
	cin>>qx>>qy>>zx>>zy;
	printf("%d",bfs(qx,qy));
	return 0;
}

广搜流读入都比深搜跑得快无数倍,他优秀就优秀在找到的第一个头就一定是最优路径=_=
主要是我深搜和广搜写的几乎一摸一样,所以经常就忽略了广搜优秀的时间

对于T3到没什么,坑在于我习惯性地在bfs中while+for+if但这里注意即可能是竖直变水平也有可能是水平变竖直
so,这里代码实现的时候最后判是否合法用 while

易错代码
while(tail>=head)
	{
		head++;
		for(int i=0;i<4;i++)
		{
			x=t[head][1]+gox[i];
			y=t[head][2]+goy[i];
			while(x>=1&&x<=n&&y>=1&&y<=m&&a[x][y]==0)//这里!!!!
			{
				if(x==ex&&y==ey)
				{
					printf("%d",t[tail][3]);
					return;
				}
				a[x][y]=1;
				tail++;
				t[tail][1]=x;
				t[tail][2]=y;
				t[tail][3]=t[head][3]+1;
				x+=gox[i];
				y+=goy[i];
			}
		}
	}

对于T4,核心代码与T3同(但要注意n,m的长宽是反的),重点在于复习次数未知的读入

点击查看代码
int main()
{
	char x;
	scanf("%d%d",&n,&m);
	for(int i=1;i<=m;i++)
	{
		x=getchar();
		for(int j=1;j<=n;j++)
		{
			x=getchar();
			if(x==' ')a[i][j]=0;
			else a[i][j]=1;
		}
	}
	scanf("%d%d%d%d",&by,&bx,&ey,&ex);
	while(bx||by||ex||ey)
	{
		a[ex][ey]=0;
		bfs();
		a[ex][ey]=1;
		scanf("%d%d%d%d",&by,&bx,&ey,&ex);
	}
	return 0;
}
posted @ 2022-01-28 09:33  fervency  阅读(28)  评论(0编辑  收藏  举报