POJ 1852 Ants || UVA 10881 - Piotr's Ants 经典的蚂蚁问题
两题很有趣挺经典的蚂蚁问题。
1.n只蚂蚁以1cm/s的速度在长为L的竿上爬行,当蚂蚁爬到竿子的端点就会掉落。当两只蚂蚁相撞时,只能各自反向爬回去。对于每只蚂蚁,给出距离左端的距离xi,但不知道它的朝向,求所有蚂蚁落下竿子所需要的时间的最大值和最小值。
2.问题1的升级版:把问题1改为已知每只蚂蚁的左端距离和它的朝向,要求按输入顺序输出 t 秒后每只蚂蚁的位置和状态(掉出去,转向中,或者蚂蚁的朝向)。
1.POJ 1852 Ants
http://poj.org/problem?id=1852
思路:
很水的一题,因为以前做过问题2.so......
因为蚂蚁碰撞会反向,故我们可以直接看成是蚂蚁直接穿过去。
也就是说,这道题求解只需要独立的计算出每只蚂蚁到端点的时间即可。
最小时间只需要沿着靠近的一端走,最大时间则最远的一端。
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int a,L,n;
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int min_ans=0,max_ans=0;
scanf("%d%d",&L,&n);
for(int i=0;i<n;i++)
{
scanf("%d",&a);
min_ans=max(min_ans,min(L-a,a)); //选择小的一段走
max_ans=max(max_ans,max(L-a,a)); //选择长的一段走
//因为是计算总的时间故应取最大值。
}
printf("%d %d\n",min_ans,max_ans);
}
return 0;
}
2.UVA 10881 - Piotr's Ants
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=1822
思路:
《算法竞赛入门经典-训练指南》上的题。
半年前被虐个半死,今天是我把他虐个半死。
和问题1的差别在于要求出位置。
那么,同样的,每只蚂蚁碰撞后反向,所以每只蚂蚁的相对顺序不变。(突然想起“不撞南墙不回头”。。。。。。。)
所以我们根据一开始排个序,记录此时所有蚂蚁的序号,然后计算ts后的位置。(计算我们直接加上距离,你想,0s有一只向右的位置在x的,那么ts后一只向右的位置在x+t的,不管是不是一开始向右的那只还是和他碰撞的,我们可以看为穿过去)
接下来再次根据位置排序,将序号进行“还原”,即对应上原来在竿上的位置。
最后根据序号按顺序输出即可。
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=10000+10;
int L,t,n;
int order[MAXN];
char string[][10]={"L","R","Turning"};
struct data
{
int id; //输入的顺序
int x; //位置
int dir; //方向 0 左 1右 2碰撞
bool operator<(const data &y)const{
return x<y.x;
}
}a[MAXN];
bool cmp(const data& x,const data&y)
{
return x.id<y.id;
}
int main()
{
int T,kase=1;
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&L,&t,&n);
for(int i=0;i<n;i++)
{
char dir;
scanf("%d %c",&a[i].x,&dir);
if(dir=='L') a[i].dir=0;
else a[i].dir=1;
a[i].id=i;
}
//每只蚂蚁的相对次序是不变的,原来在左边的之后还会在左边。
sort(a,a+n); for(int i=0;i<n;i++)
{
order[i]=a[i].id;
if(a[i].dir==0)
a[i].x-=t;
else
a[i].x+=t;
}
//再次排序即可由最后的位置确定对应的输入序号(相对位置不变)
sort(a,a+n);
for(int i=0;i<n-1;i++)
{
a[i].id=order[i];
if(a[i].x==a[i+1].x)
a[i+1].dir=a[i].dir=2;
}
a[n-1].id=order[n-1]; sort(a,a+n,cmp); //根据输入的顺序排序
printf("Case #%d:\n",kase++);
for(int i=0;i<n;i++)
{
if(a[i].x<0||a[i].x>L) //掉出去了
printf("Fell off\n");
else
printf("%d %s\n",a[i].x,string[a[i].dir]); //根据方向输出状态。
}
printf("\n");
}
return 0;
}
POJ 1852 Ants || UVA 10881 - Piotr's Ants 经典的蚂蚁问题的更多相关文章
- UVA.10881 Piotr's Ants (思维题)
UVA.10881 Piotr's Ants (思维题) 题意分析 有一根长度为L cm的木棍,上有n只蚂蚁,蚂蚁要么向左爬,要么向右,速度均为1cm/s,若2只蚂蚁相撞,则蚂蚁同时调头.求解第T秒时 ...
- 思维题 UVA 10881 Piotr's Ants
题目传送门 /* 题意:在坐标轴上一群蚂蚁向左或向右爬,问经过ts后,蚂蚁的位置和状态 思维题:本题的关键1:蚂蚁相撞看作是对穿过去,那么只要判断谁是谁就可以了 关键2:蚂蚁的相对位置不变 关键3:o ...
- cogs 1456. [UVa 10881,Piotr's Ants]蚂蚁
1456. [UVa 10881,Piotr's Ants]蚂蚁 ★ 输入文件:Ants.in 输出文件:Ants.out 简单对比时间限制:1 s 内存限制:128 MB [题目描述 ...
- UVA 10881 Piotr's Ants(等效变换 sort结构体排序)
Piotr's AntsTime Limit: 2 seconds Piotr likes playing with ants. He has n of them on a horizontal po ...
- [ACM_模拟] UVA 10881 Piotr's Ants[蚂蚁移动 数组映射 排序技巧]
"One thing is for certain: there is no stopping them;the ants will soon be here. And I, for one ...
- UVA 10881 - Piotr's Ants【模拟+思维】
题目链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- uva 10881 Piotr's Ants 解题报告
题目链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=20&pa ...
- Uva 10881 Piotr’s Ants 蚂蚁
一根长度为 L 厘米的木棍上有 n 只蚂蚁,每只蚂蚁要么朝左爬,要么朝右爬,速度为 1 厘米/秒.当两只蚂蚁相撞时,二者同时调头(掉头用的时间忽略不计).给出每只蚂蚁的初始位置和朝向,计算 T 秒之后 ...
- uva 10881 - Piotr's Ants
这个题的突破点就在于蚂蚁不能够穿过对方,故相对位置不变: 另外,又可以把蚂蚁看成运动方向不变: 代码: #include<cstdio> #include<algorithm> ...
随机推荐
- ItelliJ IDEA开发工具使用—创建一个web项目(转)
最近想用IDEA编辑器开发,但是平时都用MyEclipse和eclipse习惯了,突然间用IDEA到处碰壁的感觉.在不断的摸索之后终于苦尽甘来,学会了基本的web程序如何创建以及运行了.期间在网上找了 ...
- C++语言笔记系列之十三——派生类构造函数的调用
1.派生类构造函数的调用 (1)一个基类的全部数据成员均被派生类继承.创建一个派生类对象时.系统在为派生类对象分配单元时一定要为其基类数据成员分配子空间. (2)一个派生类对象在创建时不仅要调用派生类 ...
- vim 实际行跟屏幕行移动命令
我们使用vim的时候,经常会碰到那种情况,就是我们输入的内容过长,中间一直不换行.当我们一行的长度超出电脑屏幕的时候,我们会发现这时候文字自动换行了.不过,如果你使用行号看的话,其实这新的一行是没有行 ...
- 76.QT槽的机制
按钮点击获取文本框输入 void Dialog::on_pushButton_clicked() { //获取文本输入 QString vstr = ui->lineEdit->text( ...
- 微信小程序,前端大梦想(二)
微信小程序之数据缓存实例-备忘录 数据缓存在移动端的使用是非常重要的,既可以减少用户的流量支出又可以提高程序的访问速度和用户体验.每个微信小程序都可以有自己的本地缓存,可以通过 wx.setS ...
- arp---操作主机的arp缓冲区
简介 arp命令用于操作主机的arp缓冲区,可以用来显示arp缓冲区中的所有条目.删除指定的条目或者添加静态的ip地址与MAC地址对应关系. 选项 -a<主机>:显示arp缓冲区的所有条目 ...
- 【CS Round #39 (Div. 2 only) C】Reconstruct Sum
[Link]:https://csacademy.com/contest/round-39/task/reconstruct-sum/ [Description] 给你一个数字S; 让你找有多少对A, ...
- TCP/IP图解学习总结(二)
注意:这里的第n层是依照OSI协议来的 I 网桥--2层交换机.数据链路层面上链接两个网络的设备.它可以识别数据链路层中的数据帧. II 路由器-3层交换机.网络层面上连接两个网络,并对分组报文 ...
- QTemporaryDir及QTemporaryFile建立临时目录及文件夹(创建一个随机名称的目录或文件,两者均能保证不会覆盖已有文件)
版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址:本文标题:QTemporaryDir及QTemporaryFile建立临时目录及文件夹 本文地址: ...
- malloc,colloc,realloc内存分配,动态库,静态库的生成与调用
1.在main方法里面直接定义一个很大的数组的时候.可能会出现栈溢出:错误代码演示: #include<stdio.h> #include<stdlib.h> void ...