POJ 1852 Ants(模拟+弹性碰撞)

来源:互联网 发布:重庆seo公司 编辑:程序博客网 时间:2024/05/16 08:29

原题地址

http://poj.org/problem?id=1852

题意:在一根长为L厘米的水平木棍上有n只蚂蚁,它们以每秒1cm/s的速度走到木棍一端就会掉下去。现在知道它们起始位置(相对于木棍左端点的距离)。但是不知道它们爬行的方向。两只蚂蚁相遇后,它们会掉头往反方向走。求所有蚂蚁都落下木棍的最短时间和最长时间。

解题思路

如果采用穷举搜索的办法枚举所有蚂蚁的初始朝向,那么复杂度为O(2^n),当n在百万数量级时,运行时间无法想象。对算法优化如下:

  • 对于最短时间,显然当所有蚂蚁都朝离自己最近的端点前进时,总时间最短,但必须满足所有蚂蚁都掉下去,所以要取所有蚂蚁到最近端距离的最大值

  • 对于最长时间,题目中描述的两只蚂蚁相遇后掉头这种行为,本质上对时间没有影响,只要忽略两只蚂蚁的区别就可以看作各自保持原样前进。因此可以要让蚂蚁都朝向离自己最远的端点,取所有蚂蚁到最远端点距离的最大值即可。(实际上只需要看最两侧的蚂蚁,但是排序会增加复杂度)

AC代码

#include <iostream>#include <algorithm>using namespace std;const int maxn = 1000005;int pos[maxn];int main(){    int kase, length, n;    cin >> kase;    while (kase--)    {        cin >> length >> n;        for (int i = 0; i<n; ++i)            cin >> pos[i];        //计算最短时间,所有蚂蚁朝最近端点的方向        int minT = 0;        for (int i = 0; i<n; ++i)            //注意取max保证所有都掉下去            minT = max( minT, min(pos[i], length-pos[i]) );        //计算最长时间,所有蚂蚁朝向最远端点的方向        int maxT = 0;        for (int i = 0; i<n; ++i)            maxT = max( maxT, max(pos[i], length-pos[i]) );        cout << minT << ' ' << maxT << endl;    }    return 0;}

算法复杂度:O(n)
耗时:610ms(估计测试的n较大)

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 婴儿吃了奶嘴不吸母乳怎么办 十一个月宝宝断奶不喝奶粉怎么办 孩子三门成绩全不及格家长该怎么办 宝宝快十个月了还不会爬怎么办 小孩写字老把手向里扭曲怎么办 孩子该上四年级了数学差的很怎么办 孩子上三年级了数学成绩好差怎么办 三年级数学老考70-80分怎么办 叛逆期的孩子用死来威胁家长怎么办 叛逆期的孩子抽烟喝酒家长该怎么办 大学遇到不好的老师加课怎么办 两岁的宝宝脾气古怪不听话怎么办 16个月宝宝不听话脾气大怎么办 如果你很害怕去面对一件事怎么办 孩子上幼儿园哭老师不理孩子怎么办 发现幼儿园给孩子吃药片该怎么办 做老师的打学生被家长投诉怎么办 学生认为老师向家长打报告怎么办 老师发打12分的试卷给家长怎么办 孩子在学校顶撞老师不让上学怎么办 被老师骂了不敢去学校怎么办 孩子不爱去幼儿园 总是哭怎么办呢 孩子在幼儿园被老师罚家长该怎么办 孩子不喜欢幼儿园里的体能课怎么办 初中叛逆期的孩子怎么办老师做法 二年级孩子不受老师待见怎么办 孩子该上初中了没学籍怎么办 四个多月的婴儿不喜欢看人怎么办 2个月婴儿不喜欢吃奶粉怎么办 想学习但是又学不进去怎么办 在省外读书 回来读高中学籍怎么办 一岁宝宝这几天不爱吃饭怎么办 2岁的宝宝吃多了怎么办 小孩吃了退烧药吐了怎么办 牙齿与牙齿之间有洞喜欢塞牙怎么办 胃有点烧心天天没食欲不饿怎么办 1岁半宝宝不吃饭光喝奶粉怎么办 一岁半宝宝光喝奶粉不吃饭怎么办 一岁半的宝宝光喝奶粉不吃饭怎么办 两岁半宝宝光喝奶粉不吃饭怎么办 宝宝9个月不好好吃饭奶粉怎么办