基础算法(搜索):NOIP 2015 斗地主
Description
牛牛最近迷上了一种叫斗地主的扑克游戏。斗地主是一种使用黑桃、红心、梅花、方片的A到K加上大小王的共54张牌来进行的扑克牌游戏。在斗地主中,牌的大小关系根据牌的数码表示如下:3<4<5<6<7<8<9<10<J<Q<K<A<2<小王<大王,而花色并不对牌的大小产生影响。每一局游戏中,一副手牌由n张牌组成。游戏者每次可以根据规定的牌型进行出牌,首先打光自己的手牌一方取得游戏的胜利。现在,牛牛只想知道,对于自己的若干组手牌,分别最少需要多少次出牌可以将它们打光。请你帮他解决这个问题。需要注意的是,本题中游戏者每次可以出手的牌型与一般的斗地主相似而略有不同。具体规则如下:
Input
第一行包含用空格隔开的2个正整数T,N,表示手牌的组数以及每组手牌的张数。
Output
共T行,每行一个整数,表示打光第T组手牌的最少次数。
Sample Input
7 4
8 4
9 1
10 4
11 1
5 1
1 4
1 1
Sample Output
HINT
共有1组手牌,包含8张牌:方片7,方片8,黑桃9,方片10,黑桃J,黑桃5,方
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
const int N=;
int cnt[N];
int DFS(int d=){
int flag=,ret=;
for(int i=;i<=;i++)
if(cnt[i])flag=;
if(!flag)return ;
for(int i=;i<=;i++){
flag=;
for(int j=i;j<=i+;j++)if(!cnt[j])flag=;
if(!flag)continue;
for(int j=i;j<=i+;j++)cnt[j]-=;
for(int j=i+;j<=;j++){
if(cnt[j]){cnt[j]-=;ret=min(ret,DFS()+);}
else{for(int k=j-;k>=i;k--)cnt[k]+=;break;}
}
} for(int i=;i<=;i++){
flag=;
for(int j=i;j<=i+;j++)if(cnt[j]<)flag=;
if(!flag)continue;
for(int j=i;j<=i+;j++)cnt[j]-=;
for(int j=i+;j<=;j++){
if(cnt[j]>=){cnt[j]-=;ret=min(ret,DFS()+);}
else{for(int k=j-;k>=i;k--)cnt[k]+=;break;}
}
} for(int i=;i<=;i++){
flag=;
for(int j=i;j<=i;j++)if(cnt[j]<)flag=;
if(!flag)continue;
for(int j=i;j<=i;j++)cnt[j]-=;
for(int j=i+;j<=;j++){
if(cnt[j]>=){cnt[j]-=;ret=min(ret,DFS()+);}
else{for(int k=j-;k>=i;k--)cnt[k]+=;break;}
}
} //三带一 三带二
for(int i=;i<=;i++){
if(cnt[i]<)continue;
cnt[i]-=;
for(int j=;j<=;j++){
if(i==j)continue;
if(cnt[j]>=){cnt[j]-=;ret=min(ret,DFS()+);cnt[j]+=;}
if(cnt[j]){cnt[j]-=;ret=min(ret,DFS()+);cnt[j]+=;}
}
cnt[i]+=;
} for(int i=;i<=;i++){
if(cnt[i]<)continue;
cnt[i]-=;
for(int j=;j<=;j++)if(i!=j&&cnt[j]>)
for(int k=j+;k<=;k++)if(i!=k&&cnt[k]>)
{cnt[j]-=;cnt[k]-=;ret=min(ret,DFS()+);cnt[j]+=;cnt[k]+=;} for(int j=;j<=;j++)if(i!=j&&cnt[j])
for(int k=j+;k<=;k++)if(i!=k&&cnt[k])
{cnt[j]-=;cnt[k]-=;ret=min(ret,DFS()+);cnt[j]+=;cnt[k]+=;}
cnt[i]+=;
}
flag=;
for(int i=;i<=;i++)if(cnt[i])flag+=;
return min(ret,flag);
}
int T,n;
int main(){
//freopen("landlords.in","r",stdin);
//freopen("landlords.out","w",stdout);
scanf("%d%d",&T,&n);
while(T--){
memset(cnt,,sizeof(cnt));
for(int i=,a,b;i<=n;i++){
scanf("%d%d",&a,&b);
cnt[a]+=;
}
cnt[]=cnt[];cnt[]=;
printf("%d\n",DFS());
}
return ;
}
基础算法(搜索):NOIP 2015 斗地主的更多相关文章
- Luogu 2668 NOIP 2015 斗地主(搜索,动态规划)
Luogu 2668 NOIP 2015 斗地主(搜索,动态规划) Description 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来 ...
- 洛谷 P2668 & P2540 [ noip 2015 ] 斗地主 —— 搜索+贪心
题目:https://www.luogu.org/problemnew/show/P2668 https://www.luogu.org/problemnew/show/P2540 首先,如果没有 ...
- [NOIp 2015]斗地主
Description 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3& ...
- [BZOJ 4325][NOIP 2015] 斗地主
一道防AK好题 4325: NOIP2015 斗地主 Time Limit: 30 Sec Memory Limit: 1024 MBSubmit: 820 Solved: 560[Submit] ...
- [NOIP 2015] 斗地主 landlord
想起几个月之前的 noip2015-只会瞎搞-这道题骗了 30 分.T T 题目 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的 A 到 K 加上大小王的共 54 张牌 ...
- noip 2015 斗地主 大爆搜!!!
反正肯定是大模拟 但是每一个可以出的牌都搜一定不是最优的 考虑最特殊的出牌方案:顺子(单,对,三) 每一种方案再加上暴力贪心打出剩下的牌的步数 #include<cstdio> #incl ...
- 算法与数据结构基础 - 广度优先搜索(BFS)
BFS基础 广度优先搜索(Breadth First Search)用于按离始节点距离.由近到远渐次访问图的节点,可视化BFS 通常使用队列(queue)结构模拟BFS过程,关于queue见:算法与数 ...
- 算法与数据结构基础 - 深度优先搜索(DFS)
DFS基础 深度优先搜索(Depth First Search)是一种搜索思路,相比广度优先搜索(BFS),DFS对每一个分枝路径深入到不能再深入为止,其应用于树/图的遍历.嵌套关系处理.回溯等,可以 ...
- 0算法基础学算法 搜索篇第二讲 BFS广度优先搜索的思想
dfs前置知识: 递归链接:0基础算法基础学算法 第六弹 递归 - 球君 - 博客园 (cnblogs.com) dfs深度优先搜索:0基础学算法 搜索篇第一讲 深度优先搜索 - 球君 - 博客园 ( ...
随机推荐
- WPF动画之路径动画(3)
XAML代码: <Window x:Class="路径动画.MainWindow" xmlns="http://schemas.microsoft.com/winf ...
- 尚学堂马士兵Oracle教程笔记
检查Oracle安装 首先,以超级管理员的身份登录oracle sqlplus sys/bjsxt as sysdba 然后,解除对scott用户的锁 alter user scott account ...
- .net闭包的应用
这里体现出闭包的数据共享 , , , , , , , , , }; ; ; values.ToList().ForEach(s => result1 += s); values.ToList() ...
- 360极速浏览器在XP系统下的一个bug
今天在做页面开发的时候,发现360浏览器在XP系统下不支持focus事件,而主流的IE(包括IE6),firefox,chrome都没有这个问题.前段开发的悲剧啊,各种浏览器兼容性的问题.
- react组件什么周期记录,转的
react 的核心除了虚拟DOM,我想还有一个很重要的就是生命周期函数,理解生命周期函数,对写出合理的commponet很有帮助.下面总结一下我对生命周期函数的一些理解已经在项目过程中遇到的一些问题. ...
- 【转】Ext.ajax.request 中的success和failure
原文链接:Ext.ajax.request 中的success和failure Ajax request对象的success事件表示request过程中没有发生错误,和自己的业务逻辑无关, 如果访问不 ...
- tree命令
tree命令以树状图列出目录的内容. 1.语法 tree(选项)(参数) 2.选项 -a:显示所有文件和目录: -A:使用ASNI绘图字符显示树状图而非以ASCII字符组合: -C:在文件和目录清单加 ...
- BZOJ3190[JLOI2013]赛车
Description 这里有一辆赛车比赛正在进行,赛场上一共有N辆车,分别称为个g1,g2--gn.赛道是一条无限长的直线.最初,gi位于距离起跑线前进ki的位置.比赛开始后,车辆gi将会以vi单位 ...
- 分享 - Social.framework
/** * 第三方分享 * * @param void 友盟分享 * @param shareSDK * @param 百度分享 */ #import "ViewController ...
- Xcode6 Xcode7 Xcode 官方链接 --备用
Xcode 6 官方下载链接: http://adcdownload.apple.com//wwdc_2014/xcode_6_beta_ie8g3n/xcode_6_beta.dmg Xcode ...