9.13度小满笔试

9.13度小满笔试第二题迷宫
自己本地跑没问题,结果只能ac0.3,菜的真实
//迷宫最短路径bfs
import java.util.*;

public class Main {
	
	public static class node{
		public int x;
		public int y;
		
		public node(int x, int y) {
			this.x=x;
			this.y=y;
		}
		
		
	}
	
public static void main(String[] args) {
		
		Scanner in=new Scanner(System.in);
		int n=in.nextInt();
		int m=in.nextInt();
		in.nextLine();
		int [][] a=new int[n][n];		
		for(int i=0;i<n;i++) {
			String s=in.nextLine();
			for(int j=0;j<n;j++) {
				if(s.charAt(j)=='#') a[i][j]=m;	
				else a[i][j]=s.charAt(j)-'0';

			}
		}
		
		System.out.print(bfs(a));
		
		
}


public static int bfs(int[][] a) {
	
	int n=a.length;
	int [][] dp=new int[n][n];
	
	int[] dx= {1,0,-1,0};
	int[]dy= {0,1,0,-1};

	int sx=0,sy=0,gx=n-1,gy=n-1;
	int nx,ny;
	for(int i=0;i<n;i++) {
		for(int j=0;j<n;j++) {
			dp[i][j]=-1;
		}
	dp[0][0]=0;	
	}
	Queue<node> que=new LinkedList();
	node first=new node(sx,sy);
	que.add(first);
	
	while(!que.isEmpty()) {
		node curNode=que.poll();
		int cx=curNode.x;
		int cy=curNode.y;
		if(cx==gx&&cy==gy) {
			return dp[gx][gy];
		}
		for(int i=0;i<4;i++) {
			 nx=cx+dx[i];
			 ny=cy+dy[i];
		
		if((0<=nx&&nx<n)&&(0<=ny&&ny<n)&&(dp[nx][ny]==-1)&&(a[nx][ny]!=0)){
			node nextNode=new node(nx,ny);
			que.add(nextNode);
			dp[nx][ny]=dp[cx][cy]+a[nx][ny];
		}
		
	}
	}
	
	return dp[gx][gy];
 }
}


#笔试题目##度小满#
全部评论
这个可能要用优先队列,每一步权重不一定是1
点赞 回复 分享
发布于 2020-09-14 11:49
0是可通过的,1是不可通过的,为啥判断是a[nx][ny]!=0
点赞 回复 分享
发布于 2020-09-14 11:33

相关推荐

不愿透露姓名的神秘牛友
09-17 15:52
点赞 评论 收藏
分享
08-27 21:03
已编辑
西南石油大学 Java
冷花幽露:大概率是了,京东面试就是这样。我上周一面也是20多分钟,面试官问的很刁钻的问题也答上来了,面完过了几天还是没推进,泡池子,昨天一看挂了。如果一面完第2天没有收到2面邀请,基本上不用抱希望了。如果你的bg是985,面试流程也是和我们一样,20多分钟,唯一区别就是面完他们会很快收到二面邮件,而不像我们泡池子然后挂掉
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
08-20 19:41
那一天的Java_J...:简历完全流水账,学生思维很严重,还有很大的优化空间,可以多看看牛客的简历。
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务