leetcode 526 优美的排列

一、题目描述

二、解题思路

整体思路

画出解决问题的决策树,可以用回溯+剪枝的方法来解决这个问题。

具体思路

以示例一为例,决策树如下图所示:

(1)剪枝策略:使用过的数字不能再使用;

(2)函数功能:dfs函数用于找到从start位置开始的优美排列;

(3)递归出口:如果start==n+1,ret++,然后return;

(4)函数体

<1>从i=1到i=n进行循环;

<2>处理当前节点,如果当前位置的数没有被使用,且满足优美排列的原则,就把used[i]更改为true,再dfs递归处理start+1位置;

<3>处理完后,回溯恢复现场;

三、代码实现

cpp 复制代码
class Solution {
    int ret=0;
    bool used[15]={false};
public:
    int countArrangement(int n) {
        dfs(1,n);
        return ret;
    }
    void dfs(int start,int n){
        //递归出口
        if(start==n+1){
            ret++;
            return ;
        }
        for(int i=1;i<=n;i++){
            if(used[i]==false&&((i%start==0)||(start%i==0))){
                used[i]=true;
                dfs(start+1,n);
                //回溯恢复现场
                used[i]=false;
            }
        }
    }
    
};
相关推荐
王老师青少年编程17 分钟前
2024年信奥赛C++提高组csp-s初赛真题及答案解析(阅读程序第3题)
c++·题解·真题·csp·信奥赛·csp-s·提高组
凡人叶枫44 分钟前
C++中输入、输出和文件操作详解(Linux实战版)| 从基础到项目落地,避坑指南
linux·服务器·c语言·开发语言·c++
CSDN_RTKLIB1 小时前
使用三方库头文件未使用导出符号情景
c++
zheyutao1 小时前
字符串哈希
算法
A尘埃1 小时前
保险公司车险理赔欺诈检测(随机森林)
算法·随机森林·机器学习
网络安全-杰克1 小时前
2026面试自动化测试面试题【含答案】
自动化测试·软件测试·面试·职场和发展
大江东去浪淘尽千古风流人物2 小时前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法
rainbow68892 小时前
Linux文件描述符与重定向原理
c++
努力学算法的蒟蒻2 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495642 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列