leet-code/src/main/java/leetcode/editor/cn/BeautifulArrangement.md

31 lines
1.3 KiB
Markdown
Raw Normal View History

2021-08-16 16:31:07 +08:00
<p>假设有从 1 到 N 的&nbsp;<strong>N&nbsp;</strong>个整数,如果从这&nbsp;<strong>N&nbsp;</strong>个数字中成功构造出一个数组,使得数组的第 <strong>i</strong>&nbsp;位 (1 &lt;= i &lt;= N) 满足如下两个条件中的一个,我们就称这个数组为一个优美的排列。条件:</p>
<ol>
<li>&nbsp;<strong>i&nbsp;</strong>位的数字能被&nbsp;<strong>i&nbsp;</strong>整除</li>
<li><strong>i</strong> 能被第 <strong>i</strong> 位上的数字整除</li>
</ol>
<p>现在给定一个整数 N请问可以构造多少个优美的排列</p>
<p><strong>示例1:</strong></p>
<pre>
<strong>输入:</strong> 2
<strong>输出:</strong> 2
<strong>解释:</strong>
第 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 整除
</pre>
<p><strong>说明:</strong></p>
<ol>
<li><strong>N</strong> 是一个正整数并且不会超过15。</li>
</ol>
<div><div>Related Topics</div><div><li>位运算</li><li>数组</li><li>动态规划</li><li>回溯</li><li>状态压缩</li></div></div>\n<div><li>👍 194</li><li>👎 0</li></div>