hdu分类 Dynamic Programming(这是一场漫长的旅途)
下面是difficulty 1的题
1003 Max Sum
最长递增子序列。非常经典,最棒的解法是在线算法O(n)的复杂度。
贴的呢,是用dp做的代码。
先是一个高亮的dp递推式,然后找到最大处,用k记录。即所求的子序列的结尾,之后倒推,用减法推出子序列的开头位置。
要注意的点就是各个变量的初始化,初始化不好,很容易WA。还有找子序列的头的时候,倒推的时候找到等值的数是不跳出的,但是更新gx的值,因为0的存在。
#include <iostream> #include <cstring> using namespace std; ]; ]; int main() { int t; cin>>t; ; while(t--) { int n; cin>>n; ;i<=n;i++) { cin>>a[i]; } memset(dp,,sizeof(dp)); ;i<=n;i++) { ]<) dp[i]=a[i]; else dp[i]=dp[i-]+a[i]; } ],k=; ;i<=n;i++) { if(dp[i]>ans) { ans=dp[i]; k=i; } } int max=ans; int gx=k,sx=k; ;i--) { max-=a[i]; ) sx=i; } cout<<"Case "<<p++<<":"<<endl; cout<<ans<<" "<<sx<<" "<<gx<<endl; ) cout<<endl; } ; }
1025 Constructing Roads In JGShining's Kingdom
这道题也是非常非常经典的,重点是怎么去想到这是一个LIS。
你把一条轴上的看成数组的下标,一条轴上的看成数组的值,一一对应起来,发现它所要求的就是该数组中的LIS。
这里写的是nlogn的LIS的方法。具体的可以看看书或者网上的博客,LIS本来朴素的做法是n²的,但是当你换一个方式dp,dp[n]表示的是长度为n+1的子序列的结尾的最大值。就可以降到nlogn。
#include <cstdio> #include <iostream> #include <algorithm> using namespace std; +; const int INF = 0x3f3f3f3f; int road[maxn],dp[maxn]; int main() { int n,x,y; ; while(~scanf("%d",&n)) { ;i<n;i++) dp[i] = INF; ;i<n;i++) { scanf("%d%d",&x,&y); road[x] = y; } ;i<=n;i++) { *lower_bound(dp,dp+n,road[i]) = road[i]; } int len = lower_bound(dp,dp+n,INF) - dp; printf("Case %d:\n",p++); printf("My king, at most %d road",len); ) printf("s"); printf(" can be built.\n\n"); } ; }
1058 Humble Numbers
这道题比较恶心的是输出,英文的序数词的格式orz。
这段dp也比较奇特,对当时的我来说。
,p2=,p3=,p5=,p7=; rec[i++] = ; ) { *rec[p2],*rec[p3]); *rec[p5],*rec[p7]); rec[i] = min( one , two ); *rec[p2]) p2++; *rec[p3]) p3++; *rec[p5]) p5++; *rec[p7]) p7++; i++; }
#include <cstdio> #include <algorithm> using namespace std; ]; int main() { ,p2=,p3=,p5=,p7=; rec[i++] = ; ) { *rec[p2],*rec[p3]); *rec[p5],*rec[p7]); rec[i] = min( one , two ); *rec[p2]) p2++; *rec[p3]) p3++; *rec[p5]) p5++; *rec[p7]) p7++; i++; } int n; while(~scanf("%d",&n) && n) { == && n% != ) printf("The %dst humble number is %d.\n",n,rec[n]); == && n% != ) printf("The %dnd humble number is %d.\n",n,rec[n]); == && n% != ) printf("The %drd humble number is %d.\n",n,rec[n]); else printf("The %dth humble number is %d.\n",n,rec[n]); } ; }
1059 Dividing
hdu分类 Dynamic Programming(这是一场漫长的旅途)的更多相关文章
- HDU 4223 Dynamic Programming?(最小连续子序列和的绝对值O(NlogN))
传送门 Description Dynamic Programming, short for DP, is the favorite of iSea. It is a method for solvi ...
- hdu 4223 Dynamic Programming?
Dynamic Programming? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Oth ...
- hdu 4223 Dynamic Programming? (dp)
//连续的和的绝对值最小 # include <stdio.h> # include <string.h> # include <algorithm> # incl ...
- hdu 4972 A simple dynamic programming problem(高效)
pid=4972" target="_blank" style="">题目链接:hdu 4972 A simple dynamic progra ...
- HDU-4972 A simple dynamic programming problem
http://acm.hdu.edu.cn/showproblem.php?pid=4972 ++和+1还是有区别的,不可大意. A simple dynamic programming proble ...
- 动态规划 Dynamic Programming 学习笔记
文章以 CC-BY-SA 方式共享,此说明高于本站内其他说明. 本文尚未完工,但内容足够丰富,故提前发布. 内容包含大量 \(\LaTeX\) 公式,渲染可能需要一些时间,请耐心等待渲染(约 5s). ...
- 动态规划 Dynamic Programming
March 26, 2013 作者:Hawstein 出处:http://hawstein.com/posts/dp-novice-to-advanced.html 声明:本文采用以下协议进行授权: ...
- Dynamic Programming
We began our study of algorithmic techniques with greedy algorithms, which in some sense form the mo ...
- 算法导论学习-Dynamic Programming
转载自:http://blog.csdn.net/speedme/article/details/24231197 1. 什么是动态规划 ------------------------------- ...
随机推荐
- jquery的offset().top 和position().top 详解 和如何用js实现
1 jquery定义: offset().top 相对于当前文档的坐标(的高度) ps:包括滚动条卷去的高度 position().top 返回的是相对于其定位的祖辈元素的坐标(的高度) ps:包括滚 ...
- MySQL基本命令
1.修改root用户登录密码: [root@17track bin]# /usr/local/mysql/bin/mysqladmin -u root password 'MyPassword' my ...
- CIDR详解和ip最长地址前缀匹配
1.CIDR是什么 无类域间路由(CIDR)编址方案 摒弃传统的基于类的地址分配方式,允许使用任意长度的地址前缀,有效提高地址空间的利用率. 就是一个ip加一个网络掩码,不过这个掩码不是之前只有3个值 ...
- ypzl药品质量不合格数据库-excel自动排版
原创: qq:231469242 import xlrdimport pandas,numpyimport matplotlib.pyplot as pltimport pandas as pd #参 ...
- java 追加文件
FileWriter writer = null; String fileName="d://my.txt"; String line="要追加的内容"; tr ...
- 面试题目——《CC150》数学与概率
面试题7.2:三角形的三个顶点上各有一只蚂蚁.如果蚂蚁开始沿着三角形的边爬行,两只或三只蚂蚁撞到一起的概率有多大?假定每只蚂蚁会随机选一个方向,每个方向被选到的几率相等,而且三只蚂蚁的爬行速度相同. ...
- php 去掉字符串的最后一个字符
原字符串1,2,3,4,5,6, 去掉最后一个字符",",最终结果为1,2,3,4,5,6 代码如下: $str = "1,2,3,4,5,6,"; $news ...
- 脑筋急转弯——Google 面试
1. 村子里有100对夫妻,其中每个丈夫都瞒着自己的妻子偷情...村里的每个妻子都能立即发现除自己丈夫之外的其他男人是否偷情,唯独不知道她自己的丈夫到底有没有偷情.村里的规矩不容忍通奸.任何一个妻子, ...
- 一次性事务和CTE插入数据的比较
有时要构造一些数据来做测试数据,像下面这样: IF OBJECT_ID(N'T14') IS NOT NULL BEGIN DROP TABLE T14 END GO CREATE TABLE T14 ...
- H5项目常见问题及注意事项
Meta基础知识: H5页面窗口自动调整到设备宽度,并禁止用户缩放页面 //一.HTML页面结构 <meta name="viewport" content="wi ...