LeetCode2741.特别的排列 状压

暴力枚举的话是n!

考虑状压DP,其实就是用二进制表示状态 再进行暴力 同时加一个记忆化就好了

这里有常用技巧:

全集(1<<n)-1

增加某个元素 x | (1<<i)

删除某个元素 x & ~(1<<i)

cpp 复制代码
const int N = 15;
int dp[1<<N][N];
vector<int>nums1;
int mod = 1e9+7;
int n;

int dfs(int u,int id){
    if(!u)return 1;
    if(~dp[u][id])return dp[u][id];

    int res = 0;
    for(int i=0;i<n;i++){
        if((u>>i&1)&&(nums1[id]%nums1[i]==0||nums1[i]%nums1[id]==0))
         res  = (res + dfs(u&~(1<<i),i))%mod;
    }
    res%=mod;
    return dp[u][id] = res;

    
}

class Solution {
public:
    int specialPerm(vector<int>& nums) {
        memset(dp,-1,sizeof dp);
        n = nums.size();
        nums1 = nums;
        nums1.push_back(1);
        return dfs((1<<n)-1,n);
    }
};
相关推荐
甄心爱学习30 分钟前
KMP算法(小白理解)
开发语言·python·算法
wen__xvn1 小时前
牛客周赛 Round 127
算法
大锦终1 小时前
dfs解决FloodFill 算法
c++·算法·深度优先
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量
算法·leetcode·职场和发展
苦藤新鸡1 小时前
14.合并区间(1,3)(2,5)=(1,5)
c++·算法·leetcode·动态规划
程序员-King.1 小时前
day145—递归—二叉树的右视图(LeetCode-199)
算法·leetcode·二叉树·递归
漫随流水1 小时前
leetcode算法(112.路径总和)
数据结构·算法·leetcode·二叉树
过期的秋刀鱼!2 小时前
机器学习-带正则化的成本函数-
人工智能·python·深度学习·算法·机器学习·逻辑回归
ScilogyHunter2 小时前
前馈/反馈控制是什么
算法·控制
山峰哥2 小时前
SQL调优实战:让查询效率飙升10倍的降本密码
服务器·前端·数据库·sql·编辑器·深度优先