#青训营笔记创作活动# 问题描述
小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记录安全区域的个数。
#青训营笔记创作活动# 问题描述
小F正在使用一个骑士跳跃方式的拨号器。这个拨号器是一个类似电话键盘的3x4矩阵,每个数字对应一个单元格,骑士只能站在蓝色数字单元格上进行跳跃(数字1到9和0)。骑士的移动方式
和国际象棋中的马相同:它可以垂直移动两个单元格并水平移动一个单元格,或水平移动两个单元格并垂直移动一个单元格,形成“L“形。
123
456
789
*0#
给定一个整数n,你需要帮助小F计算骑士可以拨出的所有长度为n的不同电话号码的数量。骑士可以从任何数字开始,并在n-1次有效跳跃后得到一个有效号码。答案可能非常大,因此你需要返
回对10^9+7取模的结果。
测试样例
样例1:
输入:n=1输出:10
样例2:
输入:n=2输出:20
样例3:
输入:n=3输出:46
题解:
开始看到表盘以为是跳棋类的问题,但是看到后面数据较大的提示,那就使用动态规划了。于是就得到了DP[i][j]的定义:
从i开始的拨号,经过j次得到的号码数量
状态转移方程不好直接写出来:
DP[i][j]=DP[i-1][x1]+DP[i-1][x2]+...+DP[i-1][xn]
其中x1,x2...xn是能到达j的其他数字。
小F正在使用一个骑士跳跃方式的拨号器。这个拨号器是一个类似电话键盘的3x4矩阵,每个数字对应一个单元格,骑士只能站在蓝色数字单元格上进行跳跃(数字1到9和0)。骑士的移动方式
和国际象棋中的马相同:它可以垂直移动两个单元格并水平移动一个单元格,或水平移动两个单元格并垂直移动一个单元格,形成“L“形。
123
456
789
*0#
给定一个整数n,你需要帮助小F计算骑士可以拨出的所有长度为n的不同电话号码的数量。骑士可以从任何数字开始,并在n-1次有效跳跃后得到一个有效号码。答案可能非常大,因此你需要返
回对10^9+7取模的结果。
测试样例
样例1:
输入:n=1输出:10
样例2:
输入:n=2输出:20
样例3:
输入:n=3输出:46
题解:
开始看到表盘以为是跳棋类的问题,但是看到后面数据较大的提示,那就使用动态规划了。于是就得到了DP[i][j]的定义:
从i开始的拨号,经过j次得到的号码数量
状态转移方程不好直接写出来:
DP[i][j]=DP[i-1][x1]+DP[i-1][x2]+...+DP[i-1][xn]
其中x1,x2...xn是能到达j的其他数字。
展开
评论
点赞