简单DP-艰难取舍
艰难取舍(seq.cpp/c/pas)
【题目描述】
由于hyf长得实在是太帅了,英俊潇洒,风流倜傥,人见人爱,花见花开,车见车载。有一群MM排队看hyf。每个 MM都有自己独特的风格,由于 hyf有着一颗包容的心,所以,什么风格的MM他都喜欢……
但是,hyf有一个特别的要求,他不希望总是看到风格得差不多的 MM,更加特别的是,如果两个MM风格完全一样,hyf不会有任何意见。
现在,hyf希望从去看他的 MM中,去掉一些MM,从而使得相邻2个 MM的风格值的差(绝对值)不为1。自然地,hyf希望去掉的MM越少越好。
【输入格式】
第一行一个整数N;
第 2~N+1行N 个整数,第i个为 ci。表示第i个MM的风格值。
【输出格式】
一个数,表示最少要去掉的 MM数。
【样例输入1】
6
4
2
2
1
1
1
【样例输出1】
2
【数据范围】
对于30%的数据,N≤20
对于70%的数据,N≤100,ci ≤ 2000
对于100%的数据,N≤1000 0 ≤ ci ≤ 2000
这道题可以用动态规划的算法来解决。用数组F[i]来表示从第1个到第i个数最多可以留下几个。
那么显然F[i]可以由F[j](1<=j<=i-1)加1推得。即当前最优情况下与第i个数相邻的是第j个数,并且这里的j要满足i和j的差绝对值不为1。则F[i]=max{F[j]}+1,且|a[i]-a[j]|<>1。这个算法的时间复杂度为O(n^2)。
另外,可以发现a[j]与a[i]不能相邻的情况只有a[j]=a[i]+1和a[j]=a[i]-1。所以,不需穷举1到i-1,只需找出1到i-1中最大的3个F[j]即可,其中必须确保F[j]不彼此相等,这样满足条件的max{F[j]}必然是在这3个F[j]中,这样就可将算法的时间复杂度缩小到O(3N)。
这道题也可以用暴力枚举来实现,对于一个序列a1,a2,a3…an,可以]用一个数组b[a[i]]来记录到达a[i]的最大存在个数。通过枚举存在2个,3个,4个…n个人时的最大值来取得。
例:一开始只存在a1和a2,a3…an中的任意一个时的最大值放在b[a[i]]中,然后再搜索只存在3个人时a1,a2和a3,a4….an中的任意一个时的最大值,由于a1,a2两个人的最大值已存在b[a[2]]中了,所以只要寻找a2和a3,a4…an中任意一个的最大值即可,比较b[a[i]]是否大于b[a[2]]+1,并将结果放在b[a[i]]中。同理依次枚举至n个人为止。最后在b[1]…b[n]中找出最大值即可。
for i:=1 to n do//枚举每次存在从a[1]开始的i个人
for j:=i+1 to n do//更新前i个人和到第j个人之间的最大人数
if (abs(c[j]-c[i])<>1) and (s[i]+1>s[j]) then s[j]:=s[i]+1;
AC_code:
var
j,i,n,maxs:longint;
c,f:array[..] of longint;
function max(a,b:longint):longint;
begin
if a>b then exit(a);
exit(b);
end;
begin
assign(input,'seq.in');
assign(output,'seq.out');
reset(input);rewrite(output);
readln(n);
for i:= to n do readln(c[i]);
for i:= to n do begin
f[i]:=;
for j:= to i- do
if abs(c[j]-c[i])<> then f[i]:=max(f[i],f[j]+);
end;
maxs:=-;
for i:= to n do if f[i]>maxs then maxs:=f[i];
writeln(n-maxs);
close(input);close(output);
end.
简单DP-艰难取舍的更多相关文章
- HDU 1087 简单dp,求递增子序列使和最大
Super Jumping! Jumping! Jumping! Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 ...
- Codeforces Round #260 (Div. 1) A. Boredom (简单dp)
题目链接:http://codeforces.com/problemset/problem/455/A 给你n个数,要是其中取一个大小为x的数,那x+1和x-1都不能取了,问你最后取完最大的和是多少. ...
- codeforces Gym 100500H A. Potion of Immortality 简单DP
Problem H. ICPC QuestTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100500/a ...
- 简单dp --- HDU1248寒冰王座
题目链接 这道题也是简单dp里面的一种经典类型,递推式就是dp[i] = min(dp[i-150], dp[i-200], dp[i-350]) 代码如下: #include<iostream ...
- poj2385 简单DP
J - 简单dp Crawling in process... Crawling failed Time Limit:1000MS Memory Limit:65536KB 64bit ...
- hdu1087 简单DP
I - 简单dp 例题扩展 Crawling in process... Crawling failed Time Limit:1000MS Memory Limit:32768KB ...
- poj 1157 LITTLE SHOP_简单dp
题意:给你n种花,m个盆,花盆是有顺序的,每种花只能插一个花盘i,下一种花的只能插i<j的花盘,现在给出价值,求最大价值 简单dp #include <iostream> #incl ...
- hdu 2471 简单DP
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2571 简单dp, dp[n][m] +=( dp[n-1][m],dp[n][m-1],d[i][k ...
- Codeforces 41D Pawn 简单dp
题目链接:点击打开链接 给定n*m 的矩阵 常数k 以下一个n*m的矩阵,每一个位置由 0-9的一个整数表示 问: 从最后一行開始向上走到第一行使得路径上的和 % (k+1) == 0 每一个格子仅仅 ...
- poj1189 简单dp
http://poj.org/problem?id=1189 Description 有一个三角形木板,竖直立放.上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周 ...
随机推荐
- js怎样推断一个对象{}是否为空对象,没有不论什么属性
js怎样推断一个对象{}是否为空对象,没有不论什么属性 前段时间用js写了一个相似"angularjs"用于数据绑定的东西,功能是比較简单了, 通常应该传进来的是一个ArrayLi ...
- jquery:ajax不接收返回值回
html页面a加元素的假设href=javasrcipt:void(0)会导致ajax没有收到回后台值. : <p class="chatmsg_load_more"> ...
- 采用curl库
Windows通过使用curl库: 到http://curl.haxx.se/下了个curl的源代码下来,源代码是用VC6编译的,我在VS2005下又一次进行编译.竟然仅仅有一个警告. cUrl的实现 ...
- W3C DOM 事件模型(简述)
1.事件模型 由于事件捕获与冒泡模型都有其长处和解释,DOM标准支持捕获型与冒泡型,能够说是它们两者的结合体.它能够在一个DOM元素上绑定多个事件处理器,而且在处理函数内部,thiskeyword仍然 ...
- ASP.NET MVC:01理解MVC模式
ASP.NET MVC是ASP.NET Web应用程序框架,以MVC模式为基础. MVC:Model View Controller 模型-视图-控制器Model(模型):负责对数据库的存取View( ...
- Team Foundation Server 2015使用教程--默认团队权限说明
- 编写爬虫程序的神器 - Groovy + Jsoup + Sublime(转)
写过很多个爬虫小程序了,之前几次主要用C# + Html Agility Pack来完成工作.由于.NET FCL只提供了"底层"的HttpWebRequest和"中层& ...
- 据序和中序序列或者也许为了一个二进制序列,恢复二进制和打印图像(c语言)
首先要预购和序,以恢复它: 1.首先,我们使用的是递归的方式来完成 2.递归的最小单位:一个空的树和书的前言和第一序.该序列的第一个元素是树的第一序列根,调用这种方法 3.递归的终止条件是.当这棵树的 ...
- 【Java编码准则】の #02不要在client存储未加密的敏感信息
当构建CS模式的应用程序时,在client側存储敏感信息(比如用户私要信息)可能导致非授权的信息泄漏. 对于Web应用程序来说,最常见的泄漏问题是在client使用cookies存放server端获取 ...
- hdu 3911 Black And White(线段树)
题目连接:hdu 3911 Black And White 题目大意:给定一个序列,然后有M次操作: 0 l r:表示询问l,r中最大连续1的个数 1 l r:表示将l,r区间上的数取反 解题思路:线 ...