UvaLive6662

PDF题目

题意:给出隧道长度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 模拟的更多相关文章

  1. poj 1696 Space Ant(模拟+叉积)

    Space Ant Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 3840   Accepted: 2397 Descrip ...

  2. POJ 1696 Space Ant --枚举,模拟,贪心,几何

    题意: 有很多点,从最右下角的点开始走起,初始方向水平向右,然后以后每步只能向左边走,问最多能走多少个点. 解法: 贪心的搞的话,肯定每次选左边的与它夹角最小的点,然后走过去. 然后就是相当于模拟地去 ...

  3. CygWin模拟Linux环境进行Ant批量打包

    运行环境:Windows7 + Cygwin + ant 第一种:有源码 这种方式比较 简单.利用ant打包.直接shell脚本修改 配置渠道号的文件.我们目前是用的umeng的.在AndroidMa ...

  4. 一.Jmeter+Ant+Jenkins搭建持续集成接口性能自动化测试

    微创新作品信息 1)微创新作品描述 A.为什么诞生: 1. 接口测试是测试系统组件间接口的一种测试.接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点.测试的重点是要检查数据的交换, ...

  5. 浅谈Winform事件的实现以及模拟其事件的实现(附实现源码)

    当我们初学Winform的时候被其神奇的事件功能所吸引,当点击一个按钮时,便会跳到我们所写的点击方法当中去.然而这并不符合我们对方法的理解,究竟.net在后面帮助我们实现了什么.我们怎样模拟其事件的实 ...

  6. python 模拟登陆,请求包含cookie信息

    需求: 1.通过GET方法,访问URL地址一,传入cookie参数 2.根据地址一返回的uuid,通过POST方法,传入cooki参数 实现思路: 1.理解http的GET和POST差别 (网上有很多 ...

  7. 利用ant脚本 自动构建svn增量/全量 系统程序升级包

    首先请允许我这样说,作为开发或测试,你一定要具备这种 本领.你可以手动打包.部署你的工程,但这不是最好的方法.最好的方式就是全自动化的方式.开发人员提交了代码后,可以自动构建.打包.部署到测试环境. ...

  8. Packets(模拟 POJ1017)

    Packets Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 47750 Accepted: 16182 Description ...

  9. 不会用ant打包、部署项目的工程师,不是一个好程序员(测试)

    副标题:利用ant脚本 自动构建svn增量/全量 系统程序升级包 首先请允许我这样说,作为开发或测试,你一定要具备这种本领.你可以手动打包.部署你的工程,但这不是最好的方法.最好的方式就是全自动化的方 ...

随机推荐

  1. Leetcode 200. number of Islands

    Given a 2d grid map of '1's (land) and '0's (water), count the number of islands. An island is surro ...

  2. 【BZOJ-4435】Juice Junctions 最小割树(分治+最小割)+Hash

    4435: [Cerc2015]Juice Junctions Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 20  Solved: 11[Submi ...

  3. 【BZOJ-3757】苹果树 块状树 + 树上莫队

    3757: 苹果树 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 1305  Solved: 503[Submit][Status][Discuss] ...

  4. Servlet基础-手工编写第一个servlet

    [手工编写第一个servlet] [步骤] 1.继承HttpServlet 2.重写doGet()或者doPost()方法  //这个doGet或者doPost方法取决用户提交的方式 3.在web.x ...

  5. Linux使用网盘客户端

    1. 百度网盘 - bypy https://github.com/houtianze/bypy 这是一个基于Python的命令行客户端. 安装参考上面链接的说明,或者这篇文章(推荐,有告诉你如何安装 ...

  6. Visual Studio 创建WebServer

    1.文件-->新建-->项目 2.Web-->Visual Studio 2012-->ASP.NET 空Web应用程序 3.右键项目-->添加-->新建项 4.选 ...

  7. 爬虫例子及知识点(scrapy知识点)

    新知识: 新建一个scrapy项目:scrapy startproject xxx(项目名称) 运行一个scrapy项目:scrapy crawl xxx(项目名称) 项目文件说明: 文件说明: • ...

  8. HDU 1710 Binary Tree Traversals(二叉树遍历)

    传送门 Description A binary tree is a finite set of vertices that is either empty or consists of a root ...

  9. 【Alpha版本】 第十天 11.18

    一.站立式会议照片: 二.项目燃尽图: 三.项目进展: 成 员 昨天完成任务 今天完成任务 明天要做任务 问题困难 心得体会 胡泽善 完成管理员的三大功能界面框架, 我要招聘查看报名者的列表显示 完成 ...

  10. 2 构建Mysql+heartbeat+DRBD+LVS集群应用系统系列之MySql的搭建

    preface 上一节我们讲了DRBD的原理,以及如何部署DRBD,那么现在在上一节的基础上部署Mysql 安装并启动Mysql 为了方便,我一般采用yum安装Mysql.命令如下: 在172.16. ...