UvaLive6662 The Last Ant 模拟
题意:给出隧道长度L,蚂蚁数量N,各蚂蚁位置Pi、前进方向Di,都为整数(前进方向为L或R),蚂蚁速度为1cm每秒,两蚂蚁若在整数点相遇则都反向,若不在整数点相遇则继续向前。求最后一个走出隧道的蚂蚁的编号。蚂蚁按编号1~n给出,隧道头尾位置为0和L。
题解:
模拟。
当然我们不用模拟蚂蚁实时行走,我们只用算一算蚂蚁什么时候会撞到。
给蚂蚁建个结构体,包括编号、位置、方向,方便以后操作。因为蚂蚁起始位置为整数,也总会在整数点相遇,所以所有数据都可以整数存储。
先给蚂蚁排个序,第一关键字位置,第二关键字方向,排完序后位置数值越小的在数组越前面,位置相同的L在R的前面。然后我们对每个蚂蚁进行研究,向它前进的方向找第一个与它反向而且会和它在整数点相遇的蚂蚁,跳出。记录其中最小的整数点相撞时间mint,判完所有蚂蚁后,让蚂蚁们走过mint,然后排序,将现在相同位置的蚂蚁转向。
重复上面的操作,直到没有蚂蚁会相撞。此时计算各蚂蚁出局时间,找出最后的蚂蚁,输出它的编号和总时间。
题目保证蚂蚁都会出去,不会撞死在里面。
题目没说超过2个蚂蚁撞到一起会怎么样,我是也考虑了,全部转向,不懂有没有这样的数据。
//#pragma comment(linker, "/STACK:102400000,102400000")
#include<cstdio>
#include<cmath>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
#include<stack>
#include<queue>
using namespace std;
#define ll __int64
#define usint unsigned int
#define mz(array) memset(array, 0, sizeof(array))
#define minf(array) memset(array, 0x3f, sizeof(array))
#define REP(i,n) for(int i=0;i<(n);i++)
#define FOR(i,x,n) for(int i=(x);i<=(n);i++)
#define RD(x) scanf("%d",&x)
#define RD2(x,y) scanf("%d%d",&x,&y)
#define RD3(x,y,z) scanf("%d%d%d",&x,&y,&z)
#define WN(x) printf("%d\n",x);
#define RE freopen("D.in","r",stdin)
#define WE freopen("1biao.out","w",stdout) const int inf=0x3f3f3f3f;
const int maxn=; struct ant {
int num;
char d;
int p;
}; int n,l;
ant a[maxn]; bool operator <(ant x,ant y) {
if(x.p!=y.p)return x.p<y.p;
else return x.d<y.d;
} void del(ant a[],const int &i,int &m) {
for(int j=i; j<m-; j++)
a[j]=a[j+];
m--;
} void check(int m) {
for(int q=; q<m; q++)
printf("%d.(%c,%d) ",a[q].num,a[q].d,a[q].p);
puts("");
} int main() {
int i,j,k;
while(scanf("%d%d",&n,&l)!=EOF) {
if(n== && l==)break; for(i=; i<n; i++) {
scanf(" %c%d",&a[i].d,&a[i].p);
a[i].num=i+;
} sort(a,a+n);
int m=n;
int time=;
while(m>=) {///还剩蚂蚁
int mint=inf;
for(i=; i<m; i++)
if(a[i].d=='L') {
for(j=i-; j>=; j--)
if(a[j].d=='R' && ((a[j].p+a[i].p)&)==) {
int tt=abs(a[j].p-a[i].p)/;
if(tt<mint) mint=tt;///记录会撞上的最小时间
break;
}
} else ///a[i].d=='R'
for(j=i+; j<m; j++)
if(a[j].d=='L' && ((a[j].p+a[i].p)&)==) {///(..&1)==0,省括号会逗,&优先级很低的样子
int tt=abs(a[j].p-a[i].p)/;
if(tt<mint) mint=tt;
break;
}
if(mint!=inf) {///有蚂蚁会撞上
for(i=; i<m; i++)///让蚂蚁走过mint的时间撞上
if(a[i].d=='L')a[i].p-=mint;
else a[i].p+=mint;
sort(a,a+m);///排序,将相同位置的蚂蚁挪到一起
for(i=m-; i>=; i--)///删掉走出去的蚂蚁
if((a[i].p<) || (a[i].p>l)) del(a,i,m);
i=;
while(i<m) {///把位置相同的蚂蚁全部转个向
if(a[i].p==a[i-].p&& a[i].d!=a[i-].d) {
j=i+;
while(j<m&& a[j].p==a[i].p)j++;
for(k=i-; k<j; k++)
if(a[k].d=='L')a[k].d='R';
else a[k].d='L';
i=j+;
} else i++;
}
// check(m);
sort(a,a+m);///排个序,让位置相同的蚂蚁往左的在左边,往右的在右边,不会撞
time+=mint;///统计经过的时间
} else { ///没蚂蚁会相撞了,找出最晚跑出去的蚂蚁
int maxi=-;
int maxt=-;
for(i=; i<m; i++) {
if(a[i].d=='L' && a[i].p>=maxt) {
maxt=a[i].p;
maxi=i;
} else if(a[i].d=='R' && (l-a[i].p>maxt)) {
maxt=l-a[i].p;
maxi=i;
}
// printf("%f,%d ",maxt,maxi);
}
printf("%d %d\n",maxt+time,a[maxi].num);
m=;
}
}
}
return ;
}
UvaLive6662 The Last Ant 模拟的更多相关文章
- poj 1696 Space Ant(模拟+叉积)
Space Ant Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 3840 Accepted: 2397 Descrip ...
- POJ 1696 Space Ant --枚举,模拟,贪心,几何
题意: 有很多点,从最右下角的点开始走起,初始方向水平向右,然后以后每步只能向左边走,问最多能走多少个点. 解法: 贪心的搞的话,肯定每次选左边的与它夹角最小的点,然后走过去. 然后就是相当于模拟地去 ...
- CygWin模拟Linux环境进行Ant批量打包
运行环境:Windows7 + Cygwin + ant 第一种:有源码 这种方式比较 简单.利用ant打包.直接shell脚本修改 配置渠道号的文件.我们目前是用的umeng的.在AndroidMa ...
- 一.Jmeter+Ant+Jenkins搭建持续集成接口性能自动化测试
微创新作品信息 1)微创新作品描述 A.为什么诞生: 1. 接口测试是测试系统组件间接口的一种测试.接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点.测试的重点是要检查数据的交换, ...
- 浅谈Winform事件的实现以及模拟其事件的实现(附实现源码)
当我们初学Winform的时候被其神奇的事件功能所吸引,当点击一个按钮时,便会跳到我们所写的点击方法当中去.然而这并不符合我们对方法的理解,究竟.net在后面帮助我们实现了什么.我们怎样模拟其事件的实 ...
- python 模拟登陆,请求包含cookie信息
需求: 1.通过GET方法,访问URL地址一,传入cookie参数 2.根据地址一返回的uuid,通过POST方法,传入cooki参数 实现思路: 1.理解http的GET和POST差别 (网上有很多 ...
- 利用ant脚本 自动构建svn增量/全量 系统程序升级包
首先请允许我这样说,作为开发或测试,你一定要具备这种 本领.你可以手动打包.部署你的工程,但这不是最好的方法.最好的方式就是全自动化的方式.开发人员提交了代码后,可以自动构建.打包.部署到测试环境. ...
- Packets(模拟 POJ1017)
Packets Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 47750 Accepted: 16182 Description ...
- 不会用ant打包、部署项目的工程师,不是一个好程序员(测试)
副标题:利用ant脚本 自动构建svn增量/全量 系统程序升级包 首先请允许我这样说,作为开发或测试,你一定要具备这种本领.你可以手动打包.部署你的工程,但这不是最好的方法.最好的方式就是全自动化的方 ...
随机推荐
- BZOJ1070 [SCOI2007]修车
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- Linux Dynamic Shared Library && LD Linker
目录 . 动态链接的意义 . 地址无关代码: PIC . 延迟版定(PLT Procedure Linkage Table) . 动态链接相关结构 . 动态链接的步骤和实现 . Linux动态链接器实 ...
- PHP中的一个”坑“
说一个极有可能在工作中遇到的问题——foreach的引用 foreach $arr = range(1,3); //[1,2,3] foreach($arr as &$val) { } for ...
- RabbitMQ代码第一步
Hello RabbitMQ 终于到了使用.Net连接RabbitMQ的时候了,我们首先新建一个控制台应用程序,在程序包管理控制器中NuGet中下载 RabbitMQ. Install-Package ...
- MVC5-2 MVC的管道流与路由
自定义Modue与Hander 之前讲了管道流中的Module与Hndler.现在我们可以去自定义Module和Handler Module 其实很简单,一共需要三个步骤 定义一个类去继承IHttpM ...
- CentOS编译安装nodejs
1. 从node.js官网下载最新版的node.js安装包,node.tar.gz wget https://nodejs.org/dist/v4.3.1/node-v4.3.1.tar.gz ...
- Git分支学习简记
简介 开始过了两遍Git的内容,第二天就已经忘记了分支(branch)的概念,开始还觉得不太用的到.然后又看了第二遍,才发现为什么大家说这个是Git里边极其重要的一个东西. 所谓branch,就类似于 ...
- ThreadPoolExecutor机制
一.概述 1.ThreadPoolExecutor作为java.util.concurrent包对外提供基础实现,以内部线程池的形式对外提供管理任务执行,线程调度,线程池管理等等服务: 2.Execu ...
- SaltStack之无Master和多Master(九)
SaltStack之无Master和多Master Masterless架构,无Master 实现方式: 1)关闭minion进程 2)修改配置文件 vi /etc/salt/minion file_ ...
- Saltstack 介绍、安装、配置(一)
Slatstack 介绍 官网:https://saltstack.com/ 官方源:http://repo.saltstack.com/ (介绍各操作系统安装方法) http://repo.sal ...