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

相关推荐

昨天 12:06
复旦大学 Java
点赞 评论 收藏
分享
秋招投简历提醒助手:个人经验是,一般面二十场左右就会进入侃侃而谈阶段。我今年七月末的时候开始的第一次面试,都是很多不会,回复很慢。后面慢慢迭代,到九月中的时候基本上面啥说啥,很放松的状态
远程面试的尴尬瞬间
点赞 评论 收藏
分享
2025-12-28 16:32
重庆邮电大学 Java
程序员花海:1.技能放最后,来面试默认你都会,技能没啥用 2.实习写的看起来没啥含金量,多读读部门文档,包装下 接LLM这个没含金量 也不要用重构这种 不会给实习生做的 3.抽奖这个还是Demo项目,实际在公司里面要考虑策略,满减,触发点,触发规则 库存 之类的,不是这个项目这么简单 4.教育背景提前,格式为 教育背景 实习 项目 技能 自我评价
简历被挂麻了,求建议
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

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