LeetCode 刷题【62. 不同路径】

62. 不同路径

自己做

解:公式计算(溢出处理)

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        int res = 1;
        bool is_all_div = false;        //标记n - 1的阶乘是否全部被除了
        vector<bool> div(n - 2, false); //标记除数(从2到n - 1,除以1没有意义,这里省略)
 
        for(int i = m; i < n + m - 1; i++){
            int number = i;

            //应除尽除【这里是为了防止多个乘数溢出的情况,那么在乘之前就先尽可能和除数相除】
            for(int j = n - 3; j >= 0; j--){
                if(!div[j] && number % (j + 2) == 0){     //发现有可以整除的除数
                    number /= (j + 2);
                    div[j] = true;                      //标记该数已经取过
                }
            }

            res *= number;

            //应除尽除【经过上面的计算,除数不一定能被完全除玩,因为可能存在上一个余数是2,下一个余数是3,而始终没有一个乘数可以和除数6整除,但事实上,2*3就可以被6整除,而2*3的存放地方就是结果res这里】
            for(int j = n - 3; j >= 0; j--){
                if(!div[j] && res % (j + 2) == 0){     //发现有可以整除的除数
                    res /= (j + 2);
                    div[j] = true;                      //标记该数已经取过
                }
            }

        }

        return res;

    }
};
相关推荐
Xの哲學7 分钟前
Linux 软中断深度剖析: 从设计思想到实战调试
linux·网络·算法·架构·边缘计算
暴风游侠11 分钟前
如何进行科学的分类
笔记·算法·分类
leaves falling37 分钟前
冒泡排序(基础版+通用版)
数据结构·算法·排序算法
老鼠只爱大米42 分钟前
LeetCode算法题详解 56:合并区间
leetcode·并查集·合并区间·区间合并·线性扫描·算法面试
蜗牛去旅行吧1 小时前
面试宝典集锦
面试·职场和发展
C雨后彩虹1 小时前
无向图染色
java·数据结构·算法·华为·面试
坚持就完事了1 小时前
扫描线算法
算法
鱼跃鹰飞1 小时前
Leetcode尊享面试100题:252. 会议室
算法·leetcode·面试
教游泳的程序员1 小时前
【面试问题精选】java开发工程师
python·面试·职场和发展
程序员-King.1 小时前
二分查找——算法总结与教学指南
数据结构·算法