小国王 骑士 状态压缩DP
// 小国王.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//
#include <iostream>
#include <vector>
using namespace std;
/*
https://loj.ac/p/10170
http://ybt.ssoier.cn:8088/problem_show.php?pid=1592
在 n x n 的棋盘上放 k 个国王,国王可攻击相邻的 8 个格子,求使它们无法互相攻击的方案总数。
输入格式
只有一行,包含两个整数 n 和 k。
输出格式
每组数据一行为方案总数,若不能够放置则输出 0。
输入
3 2
输出
16
输入
4 4
输出
79
对于全部数据,1 <= n <= 10, 0 <= k <= n^2。
*/
const int N = 12;
long long dp[N][105][1 << N];
int n, t;
int getOne(int x) {
int ret = 0;
while (x != 0) {
ret++;
x -= (x & -x);
}
return ret;
}
//检查是否有连续两个1
bool check2(int x) {
int state = 0;
while (x != 0) {
if (x & 1 && state == 1) return true;
state = x & 1;
x >>= 1;
}
return false;
}
bool check(int a, int b) {
if ( (a & b) != 0)
return false;
if (check2(a) || check2(b) || check2(a | b))
return false;
return true;
}
vector<int> state[1 << N];
//预处理所有可以转移的状态
void gen(int n) {
for (int i = 0; i < 1 << n; i++) {
for (int j = 0; j < 1 << n; j++) {
if (check(i, j)) {
state[i].push_back(j);
}
}
}
}
int main() {
cin >> n >> t;
gen(n);
dp[0][0][0] = 1;
for (int i = 1; i <= n; i++) {
for (int k = 0; k <= t; k++) {
for (int prev = 0; prev < 1 << n; prev++) {
for (auto& curr : state[prev]) {
int oneNum = getOne(curr);
if (oneNum + k <= t) {
dp[i][oneNum + k][curr] += dp[i - 1][k][prev];
}
}
}
}
}
long long ans = 0;
for (int i = 0; i < 1 << n; i++) {
ans += dp[n][t][i];
}
cout << ans << endl;
return 0;
}
作 者: itdef
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力


【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
2020-07-05 AcWing 1129. 热浪 spfa
2020-07-05 AcWing 1127. 香甜的黄油 spfa
2017-07-05 状态机学习(六)解析JSON2