hdu6188 Duizi and Shunzi (贪心或者dp)
题意
有n张牌,第i张牌上的数字是a[i]。我们定义 两张数字是一样的牌 为对子。我们定义 三张数字连续的牌 为顺子。我们想把这n张牌组成尽可能多的顺子和对子。请计算并输出能组成的最多的顺子和对子的数量。
分析
我是傻逼我是傻逼我是傻逼!重要的事情说三遍!!
这是一道贪心,而且是并不是很复杂的贪心,但是我在场上坚定的认为他是个dp然后连写带调两个小时才过掉它!
结束后我在网上查了一下,果然只有我这么傻逼,但是我还是想把这个奇怪的dp思路写下来···
我们定义f[i]为前i张牌中对子和顺子最多的数量,sum[i]为前i张牌里面和牌i相同的牌的数量(因为是排过序的,所以一定是i前面连续的几张)
如果i和前面和i相同的几张牌全部组成对子,那么f[i]=f[i-sum[i]]+sum[i]/2;
如果i和前面和i相同的几张牌想拿出一部分来和前面的组成顺子,剩下的组成对子,那么
f[i]=max(f[i],j+(sum[i]-j)/2+f[i-sum[i]-sum[i-sum[i]]-j]+(sum[i-sum[i]]-j)/2);其中j是想用来组成的顺子数。
真鸡儿麻烦哇!!!
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream> using namespace std;
const int maxn=+;
const int INF=; int n;
long long a[maxn];
long long f[maxn];
long long sum[maxn];
int main(){
while(scanf("%d",&n)!=EOF){
memset(f,,sizeof(f));
for(int i=;i<=n;i++)
scanf("%lld",&a[i]);
sort(a+,a++n);
memset(sum,,sizeof(sum));
for(int i=;i<=n;i++){
if(a[i]!=a[i-])
sum[i]=;
else
sum[i]=sum[i-]+;
}
f[]=f[]=;
if(sum[]>=)f[]=;
else f[]=;
for(int i=;i<=n;i++){
// f[i]=f[i-1];
int M;
f[i]=f[i-sum[i]]+sum[i]/; if(i-sum[i]>=&&i-sum[i]-sum[i-sum[i]-sum[i-sum[i]]]>=){
if(a[i]==a[i-sum[i]]+&&a[i]==a[i-sum[i]-sum[i-sum[i]]]+)
M=min(min(sum[i-sum[i]],sum[i-sum[i]-sum[i-sum[i]]]),sum[i]);
else M=;
// cout<<i<<" "<<M<<endl;
// f[i]=f[i-sum[i]]+sum[i]/2;
//cout<<i<<" "<<M<<endl;
// cout<<i<<" "<<M<<endl;
for(int j=;j<=M;j++){
//f[i]=max(f[i],j+(sum[i]-j)/2+f[i-sum[i]-sum[i-sum[i]-sum[i-sum[i]]]]+(sum[i-sum[i]]-j)/2);
//f[i]=max(f[i],j+f[i-sum[i]-sum[i-sum[i]-sum[i-sum[i]]]]);
f[i]=max(f[i],j+(sum[i]-j)/+f[i-sum[i]-sum[i-sum[i]]-j]+(sum[i-sum[i]]-j)/);
}
}
}
printf("%lld\n",f[n]);
/*for(int i=1;i<=n;i++){
printf("%d %d\n",i,f[i]);
}*/
//printf("%d %d",(sum[6-sum[6]]-1)/2,f[(6-sum[6]-sum[6-sum[6]-sum[6-sum[6]]])]+1);
} return ;
}
如果有谁也是这么做的一定要告诉我···难道只有我这么想吗··难受··
hdu6188 Duizi and Shunzi (贪心或者dp)的更多相关文章
- HDU 6188 Duizi and Shunzi 贪心
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6188 题意:给了n个数,然后现在问我们最多构成多少个对子和顺子,其中对子是2个相同的牌,顺子是3个连续 ...
- 【hdu6188】Duizi and Shunzi(贪心)
2017ACM/ICPC广西邀请赛 重现赛1007 Duizi and Shunzi 题意 有n张牌,问你最多能组成多少对子+顺子?一个牌只能用在一个顺子或者对子中. 题解 本来想写dp的,不会..小 ...
- Duizi and Shunzi HDU - 6188 (贪心)2017 广西ACM/ICPC
Duizi and Shunzi Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 2017ACM/ICPC广西邀请赛 1007 Duizi and Shunzi
Duizi and Shunzi Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- ALGO-13_蓝桥杯_算法训练_拦截导弹(贪心,DP)
问题描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度.某天,雷达捕捉到敌国的导弹 ...
- 【bzoj4922】[Lydsy六月月赛]Karp-de-Chant Number 贪心+背包dp
题目描述 给出 $n$ 个括号序列,从中选出任意个并将它们按照任意顺序连接起来,求以这种方式得到匹配括号序列的最大长度. 输入 第一行包含一个正整数n(1<=n<=300),表示括号序列的 ...
- 【贪心优化dp决策】bzoj1571: [Usaco2009 Open]滑雪课Ski
还有贪心优化dp决策的操作…… Description Farmer John 想要带着 Bessie 一起在科罗拉多州一起滑雪.很不幸,Bessie滑雪技术并不精湛. Bessie了解到,在滑雪场里 ...
- bzoj 1907: 树的路径覆盖【贪心+树形dp】
我是在在做网络流最小路径覆盖的时候找到这道题的 然后发现是个贪心+树形dp \( f[i] \)表示在\( i \)为根的子树中最少有几条链,\( v[i] \) 表示在\( i \)为根的子树中\( ...
- Duizi and Shunzi HDU
Duizi and Shunzi Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
随机推荐
- javascript Math.pow 函数 详解 【附】年均增长率计算
语法 Math.pow(x,y) 定义和用法 pow() 方法可返回 x 的 y 次幂的值. 处理简单数学问题 6的4次方等于1296,记作:64=1296; 求值: Math.pow(6,4)=12 ...
- Build ios app with Delphi Xe4. Lazy Social Talker ready for sale.
Yes, it is build with Delphi XE4. try it. now. What is Lazy Social Talker? Lazy Social Talker is a ...
- 【MFC】CDC::BitBlt介绍
CDC::BitBlt介绍 2011-11-04 08:25 19576人阅读 评论(6) 收藏 举报 摘自: http://blog.csdn.net/bberdong/article/detail ...
- HDU - 6096 :String (AC自动机,已知前后缀,匹配单词,弱数据)
Bob has a dictionary with N words in it. Now there is a list of words in which the middle part of th ...
- Arcgis Desktop连接GIS Servers报错“Proxy server got bad address from remote server ...”
今天打开Arcgis Desktop时突然发现连接GIS Servers报错“Proxy server got bad address from remote server ...” 网上查找到解决方 ...
- 剑指offer-第六章面试中的各项能力(n个骰子的点数)
题目:把n个骰子扔到地上,骰子之和为S,输入n,打印s所有可能的值出现的概率. 思路:由于骰子的点数为1~6,因此n个骰子之和的大小为n~6n之间.故可以定义一个数组来存放这6n-n+1个数出现的次数 ...
- WPF设置全局快捷键
转自:http://www.cnblogs.com/atskyline/archive/2012/09/20/2694878.html 第一步 引入到Winows API 偷懒直接写在类里 1: [D ...
- COGS 2638. 数列操作ψ 线段树
传送门 : COGS 2638. 数列操作ψ 线段树 这道题让我们维护区间最大值,以及维护区间and,or一个数 我们考虑用线段树进行维护,这时候我们就要用到吉司机线段树啦 QAQ 由于发现若干次an ...
- 前端mvc mvp mvvm 架构介绍(vue重构项目一)
首先 我们为什么重构这个项目 1:我们现有的技术是前后台不分离,页面上采用esayUI+jq构成的单页面,每个所谓的单页面都是从后台胜场的唯一Id 与前端绑定,即使你找到了那个页面元素,也找不到所在的 ...
- ecshop其他页面判断是智能手机访问也跳转到ECTouch对应手机版页面(转)
ecshop 其他页面(商品详情页.商品分类页.团购页.优惠活动页.积分商城) 判断如果是智能手机访问跳转到ECTouch1.0手机版对应页面 方法 首先在ecshop 根目录下 includes/l ...