C++ | Leetcode C++题解之第526题优美的排列

题目:

题解:

cpp 复制代码
class Solution {
public:
    int countArrangement(int n) {
        vector<int> f(1 << n);
        f[0] = 1;
        for (int mask = 1; mask < (1 << n); mask++) {
            int num = __builtin_popcount(mask);
            for (int i = 0; i < n; i++) {
                if (mask & (1 << i) && (num % (i + 1) == 0 || (i + 1) % num == 0)) {
                    f[mask] += f[mask ^ (1 << i)];
                }
            }
        }
        return f[(1 << n) - 1];
    }
};
相关推荐
im_AMBER4 分钟前
Leetcode 43
笔记·学习·算法·leetcode
ceffans14 分钟前
PDF文档中表格以及形状解析-后续处理(线段生成最小多边形)
c++·windows·算法·pdf
mifengxing35 分钟前
力扣每日一题——接雨水
c语言·数据结构·算法·leetcode·动态规划·
小龙报1 小时前
《算法通关指南:数据结构和算法篇 --- 顺序表相关算法题》--- 询问学号,寄包柜,合并两个有序数组
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
序属秋秋秋1 小时前
《Linux系统编程之开发工具》【编译器 + 自动化构建器】
linux·运维·服务器·c语言·c++·自动化·编译器
夏玉林的学习之路2 小时前
正则表达式
数据库·c++·qt·mysql·正则表达式
小南家的青蛙2 小时前
LeetCode LCR 085 括号生成
算法·leetcode·职场和发展
夜晚中的人海2 小时前
【C++】模拟算法习题
c++·算法·哈希算法
报错小能手3 小时前
C++笔记(面向对象)多态(编译时 运行时)
c++·笔记
晨非辰3 小时前
《数据结构风云》递归算法:二叉树遍历的精髓实现
c语言·数据结构·c++·人工智能·算法·leetcode·面试