526:优美的排列

This commit is contained in:
huangge1199 2021-08-16 16:31:07 +08:00
parent d88302e760
commit 22276924d9
3 changed files with 101 additions and 1 deletions

View File

@ -0,0 +1,69 @@
//假设有从 1 N N 个整数如果从这 N 个数字中成功构造出一个数组使得数组的第 i (1 <= i <= N) 满足如下两个条件中的一个
//我们就称这个数组为一个优美的排列条件
//
//
// i 位的数字能被 i 整除
// 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 整除
//
//
// 说明:
//
//
// N 是一个正整数并且不会超过15
//
// Related Topics 位运算 数组 动态规划 回溯 状态压缩
// 👍 194 👎 0
package leetcode.editor.cn;
//526:优美的排列
class BeautifulArrangement {
public static void main(String[] args) {
//测试代码
Solution solution = new BeautifulArrangement().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public int countArrangement(int n) {
return dfs(n, 1, new boolean[n]);
}
private int dfs(int n, int index, boolean[] use) {
if (index > n) {
return 1;
}
int count = 0;
for (int i = 1; i <= n; i++) {
if (use[i - 1] || (i % index > 0 && index % i > 0)) {
continue;
}
use[i - 1] = true;
count += dfs(n, index + 1, use);
use[i - 1] = false;
}
return count;
}
}
//leetcode submit region end(Prohibit modification and deletion)
}

View File

@ -0,0 +1,31 @@
<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>

File diff suppressed because one or more lines are too long