#青训营笔记创作活动# 问题描述
小F被神秘力量带入了一个魔幻世界,这里危机四伏。为了在异世界中生存,小F需要找到安全区。异世界可以被表示为一个大小为n x m的二维数组,每个格子的值代表该位置的危险程度。
小F的能力值为X,当某个格子的危险程度小于等于X时,这个格子是安全的。如果多个安全的格子相邻(上下左右连通),它们可以构成一个安全区。你需要帮助小F计算出一共有多少个安全区。
测试样例
样例1:
输入:n = 3, m = 3, X = 4, a = [[2, 3, 3], [3, 3, 3], [3, 3, 3]]
输出:1
样例2:
输入:n = 2, m = 2, X = 5, a = [[6, 6], [6, 4]]
输出:1
样例3:
输入:n = 3, m = 3, X = 3, a = [[1, 2, 2], [2, 3, 3], [3, 4, 5]]
输出:1
题解:
一个原二维数组,新建一个visited数组记录是否经过,直接全部遍历,遇到安全值小于能力值且没经过的点就进入while循环。while循环通过队列实现安全区域的搜寻,通过maxnum记录安全区域的个数。
#青训营笔记创作活动# 问题描述
小S在一个nxm的网格迷宫中,初始位置在左上角(1,1),目标是到达右下角(n,m)。每个格子可以是黑色(表示为1)或者白色(表示为0)。他希望在移动过程中经过的黑色格子尽可能少。移
动时可以向上、下、左、右四个方向移动,但不能走出迷宫的边界。请你帮小S计算从起点到终点所需经过的最少黑色格子的数量。
测试样例
样例1:
输入:n=5,m=3,grid=[[0,1,0],[0,1,1],[0,1,0],[1,0,0],[1,0,0]]
输出:1
样例2:
输入:n=4,m=4 ,grid=[[0,0,1,0],[1,0,1,0],[1,0,0,0],[1,1,1,0]]
输出:0
样例3:
输入:n=3,m=3 ,grid= [[0,0,0], [1, 1,0],[1,1,0]]
输出:0
题解:
首先是走迷宫的问题,因为是找一条最少黑格子的线路,所以应该使用DFS,但是因为怕时间可能不通过,就使用了BFS+优先队列的组合,同时辅以visited数组记录是否走过。
其次是黑格子的数量问题,题目要求数量最少,那就使用优先队列,排列条件是走过黑格子数量最少的方法优先。
最后是一些注意的事项,比如当(0,0)就是黑格子要对第一个压入队列的元素初始化。
小S在一个nxm的网格迷宫中,初始位置在左上角(1,1),目标是到达右下角(n,m)。每个格子可以是黑色(表示为1)或者白色(表示为0)。他希望在移动过程中经过的黑色格子尽可能少。移
动时可以向上、下、左、右四个方向移动,但不能走出迷宫的边界。请你帮小S计算从起点到终点所需经过的最少黑色格子的数量。
测试样例
样例1:
输入:n=5,m=3,grid=[[0,1,0],[0,1,1],[0,1,0],[1,0,0],[1,0,0]]
输出:1
样例2:
输入:n=4,m=4 ,grid=[[0,0,1,0],[1,0,1,0],[1,0,0,0],[1,1,1,0]]
输出:0
样例3:
输入:n=3,m=3 ,grid= [[0,0,0], [1, 1,0],[1,1,0]]
输出:0
题解:
首先是走迷宫的问题,因为是找一条最少黑格子的线路,所以应该使用DFS,但是因为怕时间可能不通过,就使用了BFS+优先队列的组合,同时辅以visited数组记录是否走过。
其次是黑格子的数量问题,题目要求数量最少,那就使用优先队列,排列条件是走过黑格子数量最少的方法优先。
最后是一些注意的事项,比如当(0,0)就是黑格子要对第一个压入队列的元素初始化。
展开
评论
点赞