「NOIP2015」斗地主
传送门
Luogu
解题思路
给你们一张搜索顺序图,然后就大力模拟就好。

细节注意事项
- 爆搜题,你们懂的。。。
参考代码
写的有点丑了,洛谷上只能过加强版的88分,会T六个点
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <cctype>
#include <cmath>
#include <ctime>
#define rg register
using namespace std;
template < typename T > inline void read(T& s) {
s = 0; int f = 0; char c = getchar();
while (!isdigit(c)) f |= c == '-', c = getchar();
while (isdigit(c)) s = s * 10 + (c ^ 48), c = getchar();
s = f ? -s : s;
}
int n, ans, sum[25];
inline void dfs(int x) {
if (x >= ans) return;
int cnt = 0;
for (rg int i = 3; i <= 14; ++i) {
if (sum[i] < 1) cnt = 0;
else if ((++cnt) >= 5) {
for (rg int j = i - cnt + 1; j <= i; ++j) --sum[j];
dfs(x + 1);
for (rg int j = i - cnt + 1; j <= i; ++j) ++sum[j];
}
}
cnt = 0;
for (rg int i = 3; i <= 14; ++i) {
if (sum[i] < 2) cnt = 0;
else if ((++cnt) >= 3) {
for (rg int j = i - cnt + 1; j <= i; ++j) sum[j] -= 2;
dfs(x + 1);
for (rg int j = i - cnt + 1; j <= i; ++j) sum[j] += 2;
}
}
cnt = 0;
for (rg int i = 3; i <= 14; ++i) {
if (sum[i] < 3) cnt = 0;
else if ((++cnt) >= 2) {
for (rg int j = i - cnt + 1; j <= i; ++j) sum[j] -= 3;
dfs(x + 1);
for (rg int j = i - cnt + 1; j <= i; ++j) sum[j] += 3;
}
}
for (rg int i = 2; i <= 14; ++i) {
if (sum[i] >= 3) {
sum[i] -= 3;
for (rg int j = 2; j <= 15; ++j) {
if (i == j || sum[j] < 1) continue;
--sum[j], dfs(x + 1), ++sum[j];
}
for (rg int j = 2; j <= 14; ++j) {
if (i == j || sum[j] < 2) continue;
sum[j] -= 2, dfs(x + 1), sum[j] += 2;
}
sum[i] += 3;
}
if (sum[i] >= 4) {
sum[i] -= 4;
for (rg int j = 2; j <= 15; ++j) {
if (i == j || sum[j] < 1) continue;
--sum[j];
for (rg int k = 2; k <= 15; ++k) {
if (i == k || sum[k] < 1) continue;
--sum[k], dfs(x + 1), ++sum[k];
}
++sum[j];
}
for (rg int j = 2; j <= 14; ++j) {
if (i == j || sum[j] < 2) continue;
sum[j] -= 2;
for (rg int k = 2; k <= 14; ++k) {
if (i == k || sum[k] < 2) continue;
sum[k] -= 2, dfs(x + 1), sum[k] += 2;
}
sum[j] += 2;
}
sum[i] += 4;
}
}
for (rg int i = 2; i <= 15; ++i) x += sum[i] > 0;
ans = min(ans, x);
}
inline void solve() {
memset(sum, 0, sizeof sum);
for (rg int i = 1; i <= n; ++i) {
int x, y; read(x), read(y);
if (x == 0) ++sum[15];
else if (x == 1) ++sum[14];
else ++sum[x];
}
ans = 2147483647, dfs(0);
printf("%d\n", ans);
}
int main() {
#ifndef ONLINE_JUDGE
freopen("in.in", "r", stdin);
#endif
int T; read(T), read(n);
while (T--) solve();
return 0;
}
完结撒花 \(qwq\)
「NOIP2015」斗地主的更多相关文章
- LG2679 「NOIP2015」子串 线性DP
问题描述 LG2679 题解 设\(opt[i][j]\)代表A串前\(i\)个,匹配\(B\)串前\(j\)个,选择了\(k\)个子串的方案数. 转移用前缀和优化一下. \(\mathrm{Code ...
- loj2425 「NOIP2015」运输计划[二分答案+树上差分]
看到题意最小化最长路径,显然二分答案,枚举链长度不超过$\text{mid}$,然后尝试检验.````` 检验是否存在这样一个边置为0后,全部链长$\le\text{mid}$,其最终目标就是.要让所 ...
- loj2424 「NOIP2015」子串[字符串DP]
给定字符串 A,B,要求从 A 中取出互不重叠的 k 个非空子串,按照出现顺序拼起来后等于 B.求方案数.n ≤ 1000,m ≤ 200. 主要是状态的转移.先设计出$f_{i,j,k}$表长度$B ...
- 「NOIP2015」运输计划
传送门 Luogu 解题思路 首先这题可以直接二分答案,然后我们每次都把属于长度大于二分值的路径上的边标记一次,表示选这条边可以优化几条路径. 然后我们显然是要选一条覆盖次数等于需要覆盖的路径数并且长 ...
- 「译」JUnit 5 系列:条件测试
原文地址:http://blog.codefx.org/libraries/junit-5-conditions/ 原文日期:08, May, 2016 译文首发:Linesh 的博客:「译」JUni ...
- 「译」JUnit 5 系列:扩展模型(Extension Model)
原文地址:http://blog.codefx.org/design/architecture/junit-5-extension-model/ 原文日期:11, Apr, 2016 译文首发:Lin ...
- JavaScript OOP 之「创建对象」
工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...
- 「C++」理解智能指针
维基百科上面对于「智能指针」是这样描述的: 智能指针(英语:Smart pointer)是一种抽象的数据类型.在程序设计中,它通常是经由类型模板(class template)来实做,借由模板(tem ...
- 「JavaScript」四种跨域方式详解
超详细并且带 Demo 的 JavaScript 跨域指南来了! 本文基于你了解 JavaScript 的同源策略,并且了解使用跨域跨域的理由. 1. JSONP 首先要介绍的跨域方法必然是 JSON ...
随机推荐
- 《Web安全攻防 渗透测试实战指南》 学习笔记 (四)
Web安全攻防 渗透测试实战指南 学习笔记 (四) Nmap Network Mapper 是一款开放源代码的网 ...
- java与以太坊之web3j
web3j:https://docs.web3j.io/index.html 如何使用Web3j生成私钥和地址,而不只是创建密钥存储JSON文件? https://blog.csdn.net/mong ...
- Nexus-配置vPC 实验三
配置EvPC(增强的vPC),下面两个FEX可以同时被两个N5K管理.注意:FEX只支持静态的Channel-group(mode on) N5K-1配置:配置FEXN5K-1(config)#fea ...
- 关于cctype头⽂件⾥的⼀些函数
本文摘录柳神笔记: 刚刚在头⽂件那⼀段中也提到, #include 本质上来源于C语⾔标准函数库中的头⽂件 #include ,其实并不属于C++新特性的范畴,在刷PAT⼀些字符串逻辑题的时候也经常⽤ ...
- PHPStorm 使用 Xdebug
一.下载xdebug xdebug官网:https://xdebug.org/download.php 在选择下载哪个版本的xdebug的时候需要注意了,下面有两种方法,让你准确的下载自己环境对应的x ...
- 14.浏览器屏幕缩放bug修复
问题:浏览器缩放时,轮播图显示不全,滚动水平滚动条,发现图片缺失 解决:隐藏水平滚动条,页面都只提供垂直滚动条的需求 global.css /* 水平超出部分默认隐藏 */ #app { overfl ...
- Python中利用for表达式创建列表
1.for表达式语法格式及用法 for表达式利用可迭代对象创建新的列表,for表达式也称为列表推导式,具体语法格式如下: [表达式 for 循环计数器 in 可迭代对象] 例: a = [ i + i ...
- 《JavaScript高级程序设计》读书笔记(一)JavaScript简介
起于客户端数据验证特性----闭包----匿名函数----元编程等----等想要全面理解和掌握JavaScript----本质----历史----局限性 ECMAScript 脚本语言标准 JavaS ...
- pikachu-字符型注入(get) #手工注入
1.检测注入类型 http://127.0.0.1/pikachu-master/vul/sqli/sqli_str.php?name=1&submit=%E6%9F%A5%E8%AF%A2 ...
- 吴裕雄 Bootstrap 前端框架开发——Bootstrap 显示代码:多行代码带有滚动条
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...