HDU-6669-Game(模拟,贪心)
2024-09-05 15:58:04
链接:
https://vjudge.net/problem/HDU-6669
题意:
度度熊在玩一个好玩的游戏。
游戏的主人公站在一根数轴上,他可以在数轴上任意移动,对于每次移动,他可以选择往左或往右走一格或两格。
现在他要依次完成 n 个任务,对于任务 i,只要他处于区间 [ai,bi] 上,就算完成了任务。
度度熊想知道,为了完成所有的任务,最少需要移动多少次?
度度熊可以任意选择初始位置。
思路:
刚开始以为是贪心,按y拍了个序,疯狂wa,找了个题解发现是要按顺序.....
维护当前所在区间,然后找从最近的跑来跑去就行.
代码:
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 1e3+10;
struct Node
{
int x, y;
}node[MAXN];
int n;
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
int t;
cin >> t;
while (t--)
{
cin >> n;
for (int i = 1;i <= n;i++)
cin >> node[i].x >> node[i].y;
int res = 0;
int l = node[1].x, r = node[1].y;
for (int i = 2;i <= n;i++)
{
if (node[i].x >= l && node[i].y <= r)
l = node[i].x, r = node[i].y;
else if (node[i].x >= l && node[i].x <= r && node[i].y > r)
l = node[i].x;
else if (node[i].x < l && node[i].y >= l && node[i].y <= r)
r = node[i].y;
else if (node[i].x > r)
{
res += (node[i].x-r+1)/2;
l = node[i].x, r += ((node[i].x-r+1)/2)*2;
r = min(r, node[i].y);
}
else if (node[i].y < l)
{
res += (l-node[i].y+1)/2;
r = node[i].y, l -= ((l-node[i].y+1)/2)*2;
l = max(l, node[i].x);
}
}
cout << res << endl;
}
return 0;
}
最新文章
- Java,extends,继承
- BZOJ 1066 【SCOI2007】 蜥蜴
- HT图形组件设计之道(二)
- android 6.0 SDK中删除HttpClient的相关类的解决方法
- WCF学习资源收集汇总
- css3动画导航实现
- 容器适配器之priority_queue
- cocos2d-x中CCScale9Sprite的另一种实现
- C语言-创建链表及排序
- iOS 通过UIControl,自定义控件
- LINUX0.11 内核阅读笔记
- Nvidia的CUDA库现在恢复使用了
- dedecms给图片加水印覆盖整张图片
- cookie跨域共享
- 习题 6 字符串(string)和文本
- Unity3D学习笔记(二十九):AssetBundle
- Android Studio: Application Installation Failed
- harbor镜像仓库-01-搭建部署
- SqlServer自定义函数Function中调用with as
- Redis学习四:解析配置文件 redis.conf
热门文章
- rsync从linux到linux的文件同步备份
- caffe-----使用C++ 提取网络中间层特征数据
- vsftp新建用户及目录时遇到的坑
- Linux解决Python调用Matlab函数无法导入matlab.engine问题及其他注意事项
- idea 如何运行maven项目
- python 并发编程 多线程 开启线程的两种方式
- poj3761(反序表)
- [转帖]/proc/sys/net/ipv4/ 下参数理解
- IOMETER的简单使用
- springboot - 应用实践(1)认识springboot