2025.12.10 力扣每日一题

3577.统计计算机解锁顺序排列数

cpp 复制代码
class Solution {
public:
    int countPermutations(vector<int>& complexity) {
        const int MOD = 1000000007;
        long long ans = 1;// 阶乘初始值为1(0! = 1)
        //第一步:检查核心约束------所有i>0的计算机必须能被0号解锁
        for (int i = 1; i < complexity.size(); i++) {
            // 若i号复杂度 ≤ 0号 → 0号无法解锁i,无有效排列,返回0
            if (complexity[i] <= complexity[0]) {
                return 0;
            }
            // 第二步:计算有效排列数------(n-1)!(阶乘)
            ans = ans * i % MOD;// 计算1×2×...×(n-1) = (n-1)!
            // 每一步取模,避免溢出
        }
        return ans;
    }
};
相关推荐
ambition202427 分钟前
最大子数组和算法全解析:从暴力枚举到动态规划优化
数据结构·c++·算法
没头脑的男大28 分钟前
关于删除列表的那些事儿
算法
Book思议-38 分钟前
【数据结构实战】线性表的应用
c语言·数据结构·算法·链表
qq_4614893340 分钟前
C++与Qt图形开发
开发语言·c++·算法
Yzzz-F1 小时前
Problem - 2194E - Codeforces
算法
像污秽一样1 小时前
算法设计与分析-习题12.2
算法·迭代改进·分支界限
x_xbx1 小时前
LeetCode:83. 删除排序链表中的重复元素
算法·leetcode·链表
_小草鱼_1 小时前
【搜索与图论】DFS算法(深度优先搜索)
算法·深度优先·图论·回溯·递归
I_LPL2 小时前
hot100 栈专题
算法·
2401_879503412 小时前
C++中的观察者模式变体
开发语言·c++·算法