leetcode 526. 优美的排列

  1. 题目链接 https://leetcode-cn.com/problems/beautiful-arrangement/submissions/

  2. 题目描述

    1. 假设有从 1 到 N 的 个整数,如果从这 个数字中成功构造出一个数组,使得数组的第 i 位 (1 <= i <= N) 满足如下两个条件中的一个,我们就称这个数组为一个优美的排列。条件:

    2. 第 位的数字能被 整除
    3. i 能被第 i 位上的数字整除
    4. 现在给定一个整数 N,请问可以构造多少个优美的排列?

    5. 输入: 2
      输出: 2
      解释: 
      
      第 1 个优美的排列是 [1, 2]:
        第 1 个位置(i=1)上的数字是1,1能被 i(i=1)整除
        第 2 个位置(i=2)上的数字是2,2能被 i(i=2)整除
      
      第 2 个优美的排列是 [2, 1]:
        第 1 个位置(i=1)上的数字是2,2能被 i(i=1)整除
        第 2 个位置(i=2)上的数字是1,i(i=2)能被 1 整除
  3. 解题思路

    1. 回溯法:根据题设要求,将1~N按下标递增的顺序填数,填满一个就说明找到一个优美的数组
  4. 代码

    1. python
      class Solution:
          def countArrangement(self, N: int) -> int:
              vis = [0] * (N + 1)
              ans = 0
              def _dfs(index):
                  nonlocal ans, vis
                  if index == N + 1:
                      ans += 1
                      return
                  for i in range(1, N + 1):
                      if not vis[i] and (i % index == 0 or index % i == 0):
                          vis[i] = 1
                          _dfs(index + 1)
                          vis[i] = 0;
              _dfs(1)
              return ans
                  
                      
          

       

    2. C++
      class Solution {
      public:
          int countArrangement(int N) {
              vector<int> vis(N + 1, 0);
              int ans = 0;
              _dfs(vis, ans, 1, N + 1);
              return ans;
          }
          void _dfs(vector<int>& vis, int &ans, int index, int N){
              if(index == N)
                  ans ++;
              else{
                  for(int i = 1; i < N; i++){
                      if(not vis[i] and (i % index == 0 or index % i == 0)){
                          vis[i] = 1;
                          _dfs(vis, ans, index + 1, N);
                          vis[i] = 0; 
                      }
                  }
              }
              return ;
          }
      };

       

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值