Leecode刷题C语言之骑士拨号器

执行结果:通过

执行用时和内存消耗如下:

代码如下:

复制代码
#define MOD 1000000007

int knightDialer(int n) {
    int moves[10][4] = {
        {4, 6, -1, -1},
        {6, 8, -1, -1},
        {7, 9, -1, -1},
        {4, 8, -1, -1},
        {3, 9, 0, -1},
        {-1, -1, -1, -1},
        {1, 7, 0, -1},
        {2, 6, -1, -1},
        {1, 3, -1, -1},
        {2, 4, -1, -1}
    };
    int d[2][10] = {0};
    for (int i = 0; i < 10; i++) {
        d[1][i] = 1;
    }
    for (int i = 2; i <= n; i++) {
        int x = i & 1;
        for (int j = 0; j < 10; j++) {
            d[x][j] = 0;
            for (int k = 0; moves[j][k] != -1; k++) {
                d[x][j] = (d[x][j] + d[x ^ 1][moves[j][k]]) % MOD;
            }
        }
    }
    int res = 0;
    for (int i = 0; i < 10; i++) {
        res = (res + d[n % 2][i]) % MOD;
    }
    return res;
}

解题思路:

  1. 定义骑士的移动路径
    • 首先,需要明确骑士在每个数字上能够移动到的下一个数字。使用moves数组来表示每个数字能够移动到的下一个数字的集合。例如,数字0可以移动到数字46,数字1可以移动到数字68,依此类推。不存在的移动用-1表示。
  2. 动态规划初始化
    • 使用一个二维数组d来存储每一步在每个数字上能够到达的不同路径的数量。数组d的第一维表示步数(奇数和偶数步分别用两个子数组表示以减少空间复杂度),第二维表示数字(0到9)。
    • 初始化时,对于第一步(i=1),每个数字都只能从自己出发,所以每个数字上的路径数量都为1。
  3. 动态规划状态转移
    • 从第二步开始,对于每一步和每一个数字,计算到达该数字的不同路径的数量。这是通过遍历所有可以从当前数字出发到达的下一个数字,并累加这些下一个数字在上一步的路径数量来实现的。
    • 为了减少空间复杂度,使用滚动数组技巧,只保留当前步和上一步的信息,通过i & 1x ^ 1来切换当前步和上一步的数组。
  4. 结果汇总
    • 最后,将所有数字在n步时的路径数量相加,得到总路径数量,并对MOD取模,以防止整数溢出。

关键点

  • 动态规划:使用动态规划来记录每一步在每个数字上的路径数量,避免重复计算。
  • 滚动数组 :利用滚动数组技巧来减少空间复杂度,使空间复杂度从O(n * 10)降低到O(10)
  • 取模运算 :每一步的累加结果都对MOD取模,以防止整数溢出。

复杂度分析

  • 时间复杂度O(n * 10 * 4),因为对于每一步(n步),每个数字(10个)最多有4个可能的下一个数字。
  • 空间复杂度O(10),使用滚动数组技巧,只保留当前步和上一步的信息。
相关推荐
梵刹古音几秒前
【C语言】 循环结构
c语言·开发语言·算法
编程彩机6 分钟前
互联网大厂Java面试:从分布式事务到微服务优化的技术场景解读
java·spring boot·redis·微服务·面试·kafka·分布式事务
bbq粉刷匠7 分钟前
Java-排序2
java·数据结构·排序算法
皮皮哎哟8 分钟前
冒泡排序与数组传递全解析 一维二维指针数组及二级指针应用指南
c语言·算法·冒泡排序·二维数组·指针数组·传参·二级指针
m0_561359679 分钟前
C++代码冗余消除
开发语言·c++·算法
编程彩机10 分钟前
互联网大厂Java面试:从Spring WebFlux到分布式事务的技术场景解析
java·微服务·面试·分布式事务·spring webflux
Jm_洋洋16 分钟前
【C++进阶】虚函数、虚表与虚指针:多态底层机制剖析
java·开发语言·c++
小马爱打代码17 分钟前
MyBatis:缓存体系设计与避坑大全
java·缓存·mybatis
近津薪荼20 分钟前
优选算法——滑动窗口1(单调性)
c++·学习·算法
diediedei21 分钟前
嵌入式C++驱动开发
开发语言·c++·算法