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

69 lines
2.0 KiB
Java
Raw Normal View History

2021-08-16 16:31:07 +08:00
//假设有从 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)
}