UVA 1442 Cave 洞穴 (贪心+扫描)
2015-08-01 23:16
627 查看
题意:有一个洞穴,每个位置有一个底的高度p[i],和对应顶的高度s[i],要往里面尽量放燃料,要求燃料不能碰到顶,可以无限接近。
题解:制约燃料储放的就是顶的高度了,分别求出设当前储放位置的向两边的延伸不会碰到顶的最大高度。
设当前最大高度为level,起始位置为顶高,移动到下一格的时如果碰到顶,那么降低到s[i],如果小于p[i],那么就就提高到p[i]。
两边都扫一遍,然后取最小高度。
试了试输入优化,对于这种大量数据输入效果不错,节省了大约100ms。
题解:制约燃料储放的就是顶的高度了,分别求出设当前储放位置的向两边的延伸不会碰到顶的最大高度。
设当前最大高度为level,起始位置为顶高,移动到下一格的时如果碰到顶,那么降低到s[i],如果小于p[i],那么就就提高到p[i]。
两边都扫一遍,然后取最小高度。
试了试输入优化,对于这种大量数据输入效果不错,节省了大约100ms。
#include<bits/stdc++.h> using namespace std; const int maxn = 1e6+42; int p[maxn],s[maxn]; int h[maxn]; template<class T> inline void scan_d(T *ret) { char c;*ret=0; while((c=getchar())<'0'||c>'9'); while(c>='0'&&c<='9') { *ret = *ret*10+(c-'0'); c = getchar();} } int main() { //freopen("in.txt","r",stdin); int T; scan_d(&T); while(T--){ int n; scan_d(&n); for(int i = 0; i < n; i++) scan_d(p+i);//scanf("%d",p+i); for(int i = 0; i < n; i++) scan_d(s+i);//scanf("%d",s+i); int level = s[0]; for(int i = 0; i < n; i++){ if(level<p[i]) level = p[i]; else if(level>s[i]) level = s[i]; h[i] = level; } level = s[n-1]; int ans = 0; for(int i = n-1; i >=0; i--){ if(level<p[i]) level = p[i]; else if(level>s[i]) level = s[i]; ans += min(h[i],level) - p[i]; } printf("%d\n",ans); // if(T) putchar('\n'); } return 0; }
相关文章推荐
- Android Day12-Fragment+Menu+AutoCompleteTextView+Notificationt
- vbox磁盘空间扩容
- hdu5325 多校第三场1010
- Android的Http通信加载页面、下载图片 以及doGet、doPost请求服务器
- POJ 3463 Sightseeing
- hdu 1325
- hdu 1247 Hat’s Words 字典树
- iOS开发分分钟搞定C语言—— 字符串和指针
- Memento模式
- HDU-5340 Three Palindromes(字符串哈希)
- MySQL 5.6.13 解压版(zip版)安装配置方法
- Handler的使用
- UVALive 6041 Retrenchment(KD树 + 计算几何)
- POJ 2231 Moo Volume
- c++ 11 类成员初始化
- [LeetCode] Reverse Nodes in k-Group
- 线性表的相关基础概念
- 触动精灵远程Log模块
- 比较专家与非专家如何安全上网
- Linux下如何避免僵尸进程的产生