链接:

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;
}

最新文章

  1. Java,extends,继承
  2. BZOJ 1066 【SCOI2007】 蜥蜴
  3. HT图形组件设计之道(二)
  4. android 6.0 SDK中删除HttpClient的相关类的解决方法
  5. WCF学习资源收集汇总
  6. css3动画导航实现
  7. 容器适配器之priority_queue
  8. cocos2d-x中CCScale9Sprite的另一种实现
  9. C语言-创建链表及排序
  10. iOS 通过UIControl,自定义控件
  11. LINUX0.11 内核阅读笔记
  12. Nvidia的CUDA库现在恢复使用了
  13. dedecms给图片加水印覆盖整张图片
  14. cookie跨域共享
  15. 习题 6 字符串(string)和文本
  16. Unity3D学习笔记(二十九):AssetBundle
  17. Android Studio: Application Installation Failed
  18. harbor镜像仓库-01-搭建部署
  19. SqlServer自定义函数Function中调用with as
  20. Redis学习四:解析配置文件 redis.conf

热门文章

  1. rsync从linux到linux的文件同步备份
  2. caffe-----使用C++ 提取网络中间层特征数据
  3. vsftp新建用户及目录时遇到的坑
  4. Linux解决Python调用Matlab函数无法导入matlab.engine问题及其他注意事项
  5. idea 如何运行maven项目
  6. python 并发编程 多线程 开启线程的两种方式
  7. poj3761(反序表)
  8. [转帖]/proc/sys/net/ipv4/ 下参数理解
  9. IOMETER的简单使用
  10. springboot - 应用实践(1)认识springboot