leet-code/src/main/java/leetcode/editor/cn/BeautifulArrangement.md
2021-08-16 16:31:07 +08:00

1.3 KiB
Raw Blame History

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

  1. 第 位的数字能被 整除
  2. i 能被第 i 位上的数字整除

现在给定一个整数 N请问可以构造多少个优美的排列

示例1:

输入: 2
输出: 2
解释: 

第 1 个优美的排列是 [1, 2]:
  第 1 个位置i=1上的数字是11能被 ii=1整除
  第 2 个位置i=2上的数字是22能被 ii=2整除

第 2 个优美的排列是 [2, 1]:
  第 1 个位置i=1上的数字是22能被 ii=1整除
  第 2 个位置i=2上的数字是1ii=2能被 1 整除

说明:

  1. N 是一个正整数并且不会超过15。
Related Topics
  • 位运算
  • 数组
  • 动态规划
  • 回溯
  • 状态压缩
  • \n
  • 👍 194
  • 👎 0