动态规划之HDU水题
做水题的感觉真好系列
HDU 2084 数塔
1: 1
2: 1 2
3: 1 2 3
4: 1 2 3 4
5: 1 2 3 4 5
dp[i][j]第i行第j个数取得的最大值
dp[i][j] = max(dp[i-1][j-1], dp[i-1][j]) + a[i][j]。
代码:
/********************************************************* Problem : 2084 ( 数塔 ) Judge Status : Accepted RunId : 14525016 Language : G++ Author : G_lory Code Render Status : Rendered By HDOJ G++ Code Render Version 0.01 Beta **********************************************************/ #include <iostream> #include <cstdio> #include <algorithm> using namespace std; int a[105][105]; int dp[105][105]; int N; void solve() { for (int i = 1; i <= N; ++i) { for (int j = 1; j <= i; ++j) { dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1]) + a[i][j]; } } int ans = dp[N][1]; for (int i = 2; i <= N; ++i) { ans = max(ans, dp[N][i]); } printf("%d\n", ans); } int main() { int t; scanf("%d", &t); while (t--) { scanf("%d", &N); for (int i = 1; i <= N; ++i) for (int j = 1; j <= i; ++j) scanf("%d",&a[i][j]); solve(); } return 0; }
HDU 2044 一只小蜜蜂...
Fibonacci数列。
代码:
/********************************************************* Problem : 2044 ( 一只小蜜蜂... ) Judge Status : Accepted RunId : 14532121 Language : G++ Author : G_lory Code Render Status : Rendered By HDOJ G++ Code Render Version 0.01 Beta *********************************************************/ #include <iostream> #include <cstdio> using namespace std; typedef long long ll; ll dp[55]; void init() { dp[0] = dp[1] = 1; for (int i = 2; i <= 50; ++i) dp[i] = dp[i - 1] + dp[i - 2]; } int main() { init(); int t, a, b; scanf("%d", &t); while (t--) { scanf("%d%d", &a, &b); printf("%lld\n", dp[b - a]); } return 0; }
HDU 2041 超级楼梯
同上题。
代码:
/******************************************************** Problem : 2041 ( 超级楼梯 ) Judge Status : Accepted RunId : 14532404 Language : G++ Author : G_lory Code Render Status : Rendered By HDOJ G++ Code Render Version 0.01 Beta *********************************************************/ #include <iostream> #include <cstdio> using namespace std; typedef long long ll; ll dp[45]; void init() { dp[1] = dp[2] = 1; for (int i = 3; i <= 40; ++i) dp[i] = dp[i - 1] + dp[i - 2]; } int main() { init(); int t, a; scanf("%d", &t); while (t--) { scanf("%d", &a); printf("%lld\n", dp[a]); } return 0; }
HDU 2050 折线分割平面
一开始思路就错了,想的是一条直线最大的切割方法是把所有的面的切成两半,当然那是不可能的,最优的方法是把每条已有直线分成两段,这样该直线被已有直线分成已有直线条数+1的段,每一段把所在区域分成两半。
如果是折线,就把原有区域以最优的方式分解两次,注意两次方式相同,不能先分一次,在把第一部分的结果计算进去划第二次。因为是折线,在两条直线划分的基础上要连起来一端,所以少了1个区域。
dp[i] = dp[i-1]+((i-1)*2+1)*2-1; (我竟然忘了怎么通过递推公式求通项 = =……
(i-1)*2 原有直线(一条折线看成两条直线)条数。
((i-1)*2+1) 新加一条线段,被切割成多少分,也就是新加一条线段,多几个区域。
((i-1)*2+1)*2 因为是折线,相当于多加两条线段。
((i-1)*2+1)*2-1 折线会因为合并起来那一端减少一个区域。
代码:
/********************************************************* Problem : 2050 ( 折线分割平面 ) Judge Status : Accepted RunId : 14533258 Language : G++ Author : G_lory Code Render Status : Rendered By HDOJ G++ Code Render Version 0.01 Beta *********************************************************/ #include <iostream> #include <cstdio> using namespace std; int dp[10005]; void init() { dp[0] = 1; dp[1] = 2; for (int i = 2; i <= 10000; ++i) { //dp[i] = dp[i - 1] + ((i - 1) * 2 + 1) * 2 - 1; dp[i] = dp[i - 1] + 4 * i - 3; } } int main() { int t, n; init(); scanf("%d", &t); while (t--) { scanf("%d", &n); printf("%d\n", dp[n]); } return 0; }
动态规划之HDU水题的更多相关文章
- Let the Balloon Rise HDU水题
题意 让你统计字符串最多的那个串,并输出 分析 直接用map统计,不断更新最大值即可 代码 #include<iostream> #include<algorithm> #in ...
- hdu 2393:Higher Math(计算几何,水题)
Higher Math Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU 5832 A water problem(某水题)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- HDU 2096 小明A+B --- 水题
HDU 2096 /* HDU 2096 小明A+B --- 水题 */ #include <cstdio> int main() { #ifdef _LOCAL freopen(&quo ...
- [HDU 2602]Bone Collector ( 0-1背包水题 )
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 水题啊水题 还给我WA了好多次 因为我在j<w[i]的时候状态没有下传.. #includ ...
- HDU 5578 Friendship of Frog 水题
Friendship of Frog Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.ph ...
- HDU 5590 ZYB's Biology 水题
ZYB's Biology Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid ...
- HDU 5832 A water problem (带坑水题)
A water problem 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5832 Description Two planets named H ...
- HDU 5538 L - House Building 水题
L - House Building Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.ph ...
随机推荐
- 【toplink】 位居第一的Java对象关系可持续性体系结构
TopLink,是位居第一的Java对象关系可持续性体系结构,原署WebGain公司的产品,后被Oracle收购,并重新包装为Oracle AS TopLink.TOPLink为在关系数据库表中存储 ...
- 洛谷1890 gcd区间
题目描述 给定一行n个正整数a[1]..a[n].m次询问,每次询问给定一个区间[L,R],输出a[L]..a[R]的最大公因数. 输入输出格式 输入格式: 第一行两个整数n,m.第二行n个整数表示a ...
- 常用数据字典---bai
--常用数据字典 -- system: normal; sysdba --查询所有的逻辑对象.所有. select count(1) from dba_objects; select * from d ...
- 74HC595
74HC595 输入:串行输入 输出:并行/串行输出 用74HC595做一个流水灯 电路图 程序 /*====================== 测试74HC595 ================ ...
- 解决iphone safari上的圆角问题
-webkit-appearance : none ; /*解决iphone safari上的圆角问题*/
- java多线程下载和断点续传
java多线程下载和断点续传,示例代码只实现了多线程,断点只做了介绍.但是实际测试结果不是很理想,不知道是哪里出了问题.所以贴上来请高手修正. [Java]代码 import java.io.File ...
- BT5下安装Metasploit4.5方法
BT5与Ubuntu下安装最新版Metasploit4.5方法:(先把老版本的MSF uninstall,BT5自带的老版本Metasploit没有办法升级!) 1.下载Metasploit下的Lin ...
- 浅谈HTTP响应拆分攻击
在本文中,我们将探讨何谓HTTP响应拆分以及攻击行为是怎样进行的.一旦彻底理解了其发生原理(该原理往往被人所误解),我们就可以探究如何利用响应拆分执行跨站点脚本(简称XSS).接下来自然就是讨论如果目 ...
- Oracle----Key Word
desc|describe table_name DCL----column ----add -- add one column alter table product ); -- add multi ...
- HDU 1754 I Hate It(线段树)
点我看题目 题意 :又是一道中问题,我就不说题意了.... 思路 : 线段树,这道题跟1166差不多,改一些地方就差不多了. #include <iostream> #include & ...