穷举vs暴搜vs深搜vs回溯vs剪枝系列一>优美的排列

题目:


解析:

部分决策树:


代码设计:


代码:

java 复制代码
private int count;
    private boolean[] check;
    public int countArrangement(int n) {
        check = new boolean[n+1];
        dfs(n,1);
        return count;
    } 

    private void dfs(int n, int pos){
        if(pos == n+1){
            count++;
            return;
        }

        for(int i = 1; i <= n; i++){
            if(check[i] == false && (i % pos == 0 || pos % i == 0)){
                check[i] = true;
                dfs(n,pos+1);
                check[i] = false;//恢复现场
            }
        }
    }
相关推荐
2301_820301024 分钟前
【机器学习】支持向量机
算法·机器学习·支持向量机
拾忆-eleven11 分钟前
NLP学习路线图(二十):FastText
人工智能·算法·机器学习·nlp
你真会43 分钟前
【数据结构知识分享】顺序表详解
数据结构·学习·算法
@蓝莓果粒茶1 小时前
LeetCode第245题_最短单词距离III
c语言·c++·笔记·学习·算法·leetcode·c#
闻闻不会编程2 小时前
704. 二分查找 (力扣)
数据结构·算法·leetcode
AndrewHZ2 小时前
【图像处理基石】立体匹配的经典算法有哪些?
图像处理·算法·计算机视觉·滤波·模式识别·立体匹配
AndrewHZ2 小时前
【图像处理入门】4. 图像增强技术——对比度与亮度的魔法调节
图像处理·算法·计算机视觉·几何变换·图像增强·模式识别
不二狗2 小时前
每日算法 -【Swift 算法】查找字符串数组中的最长公共前缀
开发语言·算法·swift
不二狗3 小时前
每日算法 -【Swift 算法】将整数转换为罗马数字
开发语言·算法·swift
Moonbit3 小时前
双周报Vol.73:移除使用方法实现 trait 、新增了 “错误多态” 功能、.语法支持使用 _ 的匿名函数...
后端·算法