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;
            }
        }
    }
    
};
相关推荐
KL41802 小时前
[QT]常用控件一
开发语言·c++·qt
代码充电宝3 小时前
LeetCode 算法题【简单】49. 字母异位词分组
java·算法·leetcode·面试·哈希算法
搂鱼1145143 小时前
(二分、思维)洛谷 P4090 USACO17DEC Greedy Gift Takers P 题解
算法
YSRM4 小时前
Leetcode+Java+图论+岛屿问题
java·算法·leetcode·图论
终焉代码4 小时前
【C++】map与set底层结构——红黑树
开发语言·数据结构·c++
悠哉悠哉愿意4 小时前
【数据结构与算法学习笔记】双指针
数据结构·笔记·python·学习·算法
C_lea4 小时前
链表转置算法
算法·链表
未知陨落4 小时前
LeetCode:89.分割等和子集
算法·leetcode
Cx330❀5 小时前
《C++ STL:vector类(下)》:攻克 C++ Vector 的迭代器失效陷阱:从源码层面详解原理与解决方案
开发语言·数据结构·c++·经验分享·算法