`

蚂蚁问题

    博客分类:
  • IQ
 
阅读更多
之前看有的朋友谈百度的一道面试试题-蚂蚁问题(有一根27厘米的细木杆,在第3厘米、7厘米、11厘米、17厘米、23厘米这五个位置上各有一只蚂蚁。木杆很细,不能同时通过一只蚂蚁。开始时,蚂蚁的头朝左还是朝右是任意的,它们只会朝前走或调头,但不会后退。当任意两只蚂蚁碰头时,两只蚂蚁会同时调头朝反方向走。假设蚂蚁们每秒钟可以走一厘米的距离。编写程序,求所有蚂蚁都离开木杆的最小时间和最大时间)。关于这道题目,网上给出了很多的解释,但从整体来看,基本都是用到了等价置换(等量代换)的思想。要求最小时间,即为“最不容易”先到达两端的蚂蚁以最短的时间到达,所以我们只需找到所有蚂蚁中间的一只(共奇数只蚂蚁)或两只(共偶数只蚂蚁)到达一端的最短时间。比较麻烦的是求最长时间,有人会觉得当有很多只蚂蚁时,中间的蚂蚁们相互碰撞的次数多些会增加时间,感觉上比较复杂,可如果我们用等量代换的思想来解释就比较容易。假设中间的任意两只相邻蚂蚁即将发生碰撞,如:A ->        <-B,当A,B发生碰撞后,便有<-A    B->。A,B反向相当于<-B   A -> ,即二者继续向着原来的方向前进,对于任意相邻的发生碰撞的蚂蚁都适用,所以只需求最两端的两只蚂蚁距离两端的最远距离。由以上分析可知,如果出这样的问题,我们可以不用通过程序便能说出结果:5个点,中间蚂蚁的位置为11,即0-11-27,显然最小为11,最两端蚂蚁,0-3-27,最大为24,0-23-27,最大为23,所以最大为24。对于这个题,给出如下Java代码(随便写了几句,不符合面向对象思想)。
public class Ant {
    public static void main(String[] args){
        int length=27,points=5,min=0,max=0,temp_min=0,temp_max=0;
        int[] pos={3,7,11,17,23};
        for(int i: pos){
            temp_min=i>length-i?length-i:i;
            temp_max=i<length-i?length-i:i;
            if(temp_min>min)
                min=temp_min;
            if(temp_max>max)
                max=temp_max;
        }
        System.out.println("最短时间:"+min+"  最长时间:"+max);
    }
}有了如上的想法,我们能做出判断,为什么还要写代码呢?其实这个问题出自Waterloo Local Contest Sep.19,2004 准确描述如下:
An army of ants walk on a horizontal pole of length l cm, each with a constant speed of 1 cm/s. When a walking ant reaches an end of the pole, it immediatelly falls off it. When two ants meet they turn back and start walking in opposite directions. We know the original positions of ants on the pole, unfortunately, we do not know the directions in which the ants are walking. Your task is to compute the earliest and the latest possible times needed for all ants to fall off the pole.
The first line of input contains one integer giving the number of cases that follow. The data for each case start with two integer numbers: the length of the pole (in cm) and n, the number of ants residing on the pole. These two numbers are followed by n integers giving the position of each ant on the pole as the distance measured from the left end of the pole, in no particular order. All input integers are not bigger than 1000000 and they are separated by whitespace.

For each case of input, output two numbers separated by a single space. The first number is the earliest possible time when all ants fall off the pole (if the directions of their walks are chosen appropriately) and the second number is the latest possible such time.

Sample Input
2
10 3
2 6 7
214 7
11 12 7 13 176 23 191

Sample Output
4 8
38 207

在这里给出相应的c++代码:
#include<iostream>
using namespace std;
int main()
{
    int cases,l,n,min,max,temp_min,temp_max,pos;
    cin>>cases;
    while(cases--)
    {
        cin>>l>>n;
        min=0;
        max=0;
        while(n--)
        {
            cin>>pos;
            temp_min=pos>l-pos?l-pos:pos;
            temp_max=pos<l-pos?l-pos:pos;
            if(temp_min>min)
                min=temp_min;
            if(temp_max>max)
                max=temp_max;
        }
        cout<<min<<' '<<max<<endl;
    }
    return 0;
}
分享到:
评论

相关推荐

    风力发电机控制系统仿真设计 风力发电系统动态模拟仿真 光伏发电系统 本设计主要依据风力发电机组的控制目标和控制策略,通过使用电力系统动态模拟仿真软件PSCAD EMTDC,建立变桨距风力发电机组控制系

    风力发电机控制系统仿真设计 风力发电系统动态模拟仿真 光伏发电系统 本设计主要依据风力发电机组的控制目标和控制策略,通过使用电力系统动态模拟仿真软件PSCAD EMTDC,建立变桨距风力发电机组控制系统的模型。 为了验证控制系统模型的可用性,建立风力发电样例系统模型,对样例系统进行模拟仿真,并对所得的仿真结果进行了分析,从而证实了风力发电机组控制系统模型的可用性,然后得出了它的控制方法。

    安卓项目源码Androidafinal开源框架实例源码

    安卓项目源码Android afinal开源框架实例源码提取方式是百度网盘分享地址

    C4网络技术挑战赛B-EP1赛道解决方案与实践.zip

    C4网络技术挑战赛B-EP1赛道解决方案与实践.zip [资源说明] 1、该项目是团队成员近期最新开发,代码完整,资料齐全,含设计文档等 2、上传的项目源码经过严格测试,功能完善且能正常运行,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的高校学生、教师、科研工作者、行业从业者下载使用,可借鉴学习,也可直接作为毕业设计、课程设计、作业、项目初期立项演示等,也适合小白学习进阶,遇到问题不懂就问,欢迎交流。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 5、不懂配置和运行,可远程教学 6、欢迎下载,沟通交流,互相学习,共同进步!

    Bandgap 带隙基准,带启动电路,带版图 适合新手练习 主要包含以下仿真内容: 温度特性曲线 电源抑制比psrr仿真 稳定性仿真,整个环路的稳定性 噪声仿真,可以知道噪声的主要贡献来源 输出电压精

    Bandgap 带隙基准,带启动电路,带版图 适合新手练习 主要包含以下仿真内容: 温度特性曲线 电源抑制比psrr仿真 稳定性仿真,整个环路的稳定性 噪声仿真,可以知道噪声的主要贡献来源 输出电压精度仿真 [cool][cool]testbench有单独的仿真状态,直接安装可以运行 性价比高,可以买回去练一练

    工程机器人大赛(含全部参赛源码及资料).zip

    工程机器人大赛(含全部参赛源码及资料).zip [资源说明] 1、该项目是团队成员近期最新开发,代码完整,资料齐全,含设计文档等 2、上传的项目源码经过严格测试,功能完善且能正常运行,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的高校学生、教师、科研工作者、行业从业者下载使用,可借鉴学习,也可直接作为毕业设计、课程设计、作业、项目初期立项演示等,也适合小白学习进阶,遇到问题不懂就问,欢迎交流。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 5、不懂配置和运行,可远程教学 6、欢迎下载,沟通交流,互相学习,共同进步!

    汽车中间件市场调研报告:2023年全球汽车中间件市场销售额达到了78亿美元

    汽车中间件市场调研报告:2023年全球汽车中间件市场销售额达到了78亿美元 在数字化转型的浪潮中,汽车中间件作为连接硬件与软件的关键桥梁,正引领着汽车行业的新一轮变革。随着全球汽车产业的快速发展,中间件市场规模持续扩大,展现出前所未有的增长潜力。然而,面对复杂多变的市场环境和不断涌现的新技术,企业如何精准把握市场脉搏,实现可持续发展?本文将深入探讨全球及中国汽车中间件市场的现状、趋势及竞争格局,为您揭示咨询的重要性。 市场概况: 根据QYResearch(恒州博智)的统计及预测,2023年全球汽车中间件市场销售额达到了78亿美元(约7803百万美元),预计2030年将达到156亿美元(约15630百万美元),年复合增长率(CAGR)为10.3%(2024-2030)。这一数据不仅彰显了中间件市场的强劲增长动力,也预示着未来巨大的市场空间。 技术创新与趋势: 随着自动驾驶、车联网等技术的不断发展,汽车中间件正面临着前所未有的技术挑战与机遇。新一代中间件需要具备更高的实时性、更低的延迟以及更强的数据处理能力,以满足复杂多变的汽车应用场景。同时,云计算、大数据、人工智能等技术的融合应用,将进

    基于梯度方向的VVC帧内编码中CU划分早终止算法研究与实现

    内容概要:本文探讨了一种在VVC(Versatile Video Coding)帧内编码中基于梯度方向特性的早期终止算法,旨在减少不必要的搜索从而优化计算复杂度。文中分析了视频编码的统计特征以及不同方向梯度的影响来指导CU(Coding Unit)分割决策流程。此外还介绍了算法的具体操作步骤和逻辑分支条件。实验结果显示该方法能够显著节省编码时间,平均达到约38%-51%,尽管BD-rate有所牺牲但总体上提升了效率并保持了较好的编码性能。 适合人群:从事多媒体通信系统开发或者图像视频压缩技术领域的研究人员和工程师,特别是那些对高分辨率影像处理感兴趣的专业人士。 使用场景及目标:本研究适用于寻求提高VVC标准下编码速度而不大幅度降低质量的应用环境中,如高清或超高清实时流媒体传输和服务提供者希望加快转码过程的情况。 其他说明:作者感谢中国国家重点研发计划和其他项目对于此项工作的支持,并提供了丰富的参考文献列表用于进一步的研究。

    占空比可调方波.ms14

    占空比可调方波.ms14

    基于matlab的单指针百分数表盘识别系统 表盘识别基于计算机视觉设计,基于霍夫变算法,含GUI界面 步骤:灰度化,二值化,反色,细化,霍夫变,提取峰值,检测识别 功能:识别单指针仪表盘,显示仪表

    基于matlab的单指针百分数表盘识别系统 【表盘识别】基于计算机视觉设计,基于霍夫变算法,含GUI界面 步骤:灰度化,二值化,反色,细化,霍夫变,提取峰值,检测识别 功能:识别单指针仪表盘,显示仪表指针角度以及仪表示数,显示二值化图像,灰度化图像,变域图像。 代码结构清晰,含有注释,运算速度快,可扩展。

    简单的HTML和JavaScript代码,跨年倒计时html代码

    跨年倒计时html代码

    级联H桥储能变器,级联H桥整流器 采用栽波移相调制,功率外环电流内环控制; 相内SOC为基波均衡分量注入,相间SOC为零序电压注入法,可在短时间内使得SOC达到平衡, 下图为2单元五电平,可做多模块级

    级联H桥储能变器,级联H桥整流器 采用栽波移相调制,功率外环电流内环控制; 相内SOC为基波均衡分量注入,相间SOC为零序电压注入法,可在短时间内使得SOC达到平衡, 下图为2单元五电平,可做多模块级联,H桥整流等 提供参考文献,,Matlab为2018b

    adaceshiwaifa,adaceshiwaifa,adaceshiwaifa,adaceshiwaifa

    adaceshiwaifa,adaceshiwaifa,adaceshiwaifa,adaceshiwaifa

    光伏交直流混合微电网双下垂控制离网(孤岛)模式Matlab仿真模型 ①交直流混合微电网结构: 1.直流微电网,由光伏板+Boost变器组成,最大输出功率10 kW 2.交流微电网,由光伏板+Boos

    光伏交直流混合微电网双下垂控制离网(孤岛)模式Matlab仿真模型 ①交直流混合微电网结构: 1.直流微电网,由光伏板+Boost变器组成,最大输出功率10 kW。 2.交流微电网,由光伏板+Boost变器+LCL逆变器组成,最大输出功率15 kW。 3.互联变器(ILC),由LCL逆变器组成,用于连接交直流微电网。 ②模型内容: 1.直流微电网:采用下垂控制,控制方式为电压电流双闭环,直流母线额定电压700 V。 2.交流微电网中,Boost变器采用恒压控制,直流电容电压为700 V,LCL逆变器采用下垂控制,额定频率50 Hz,额定相电压有效值220 V。 3.ILC采用双下垂控制策略,首先将交流母线频率和直流母线电压进行归一化,使其范围控制在[-1,1],之后通过ILC的归一化下垂控制调节交流母线频率和直流母线电压的偏差,最终使二者数值相同。 4.其余部分包括采样保持、坐标变、功率滤波、SVPWM等环节。 ③仿真工况:0.75 s时刻负载由12 kW增至16 kW,可以看出系统仍能稳定运行,波形质量良好,且交流母线频率和直流母线电压归一化的参数在ILC控制下趋于一致。

    基于SpringBoot+Vue.JS开发的校园闲置物品交易系统 JAVA毕业设计 源码+数据库+论文(有项目截图)+启动教程

    基于SpringBoot+Vue.JS开发的校园闲置物品交易系统 JAVA毕业设计 源码+数据库+论文(有项目截图)+启动教程

    Android Studio实现学生信息管理系统源码(高分项目).zip

    Android Studio实现学生信息管理系统源码(高分项目).zip个人经导师指导并认可通过的高分大作业项目,评审分98分,项目中的源码都是经过本地编译过可运行的,都经过严格调试,确保可以运行!主要针对计算机相关专业的正在做大作业的学生和需要项目实战练习的学习者,资源项目的难度比较适中,内容都是经过助教老师审定过的能够满足学习、使用需求,如果有需要的话可以放心下载使用。 Android Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理

    VTK User's Guide第四版(最新的)-中文翻译版PDF

    VTK User's Guide双语版PDF

    国科大 并发数据结构与多核编程.zip

    国科大 并发数据结构与多核编程国科大并发数据结构与多核编程 -- 列车售票系统目录1. 基本结构的实现2. 使用位图加速余票查询3. 使用位图加速购票4. 懒惰计算5. 简单测试1. 基本结构的实现接下来叙述的实现均以下面的场景为例一共有三个站台一共有两趟车每趟车两节车厢,每节车厢两个座位 在本系统的时间中,将上述的应用场景表示为下图中的形式 如上图中所示,系统中会将三个站台之间的所有座位都表示出来,每一个车次使用一个单独的表示座位的数组表示,一共(2*2*2*2)16个座位,由于购票时用户只需要指定出发站、终点站以及车次号,因此系统仅需区分不同车次的座位,而对同一车次中的不同车厢的座位同等对待,车次中的每一个座位可以表示为一个类,如下面的形式class Seat { private Lock lock; private boolean available; public Seat() { } public void lock() { } public void unlock() {

    毕设&课程作业_基于C#的Winform公司管理系统.zip

    计算机系毕业设计

    过年倒计时动画html过年倒计时代码/春节倒计时网页版【春节倒计时html】

    过年倒计时动画html过年倒计时代码/春节倒计时网页版【春节倒计时html】 效果演示:https://www.ygwzjs.cn/cjdjs/ 备用一:cjdjswww.vbjcw.cn 备用二:cjdjswww.lxsjfx.cn 备用三:cjdjswww.seoheimao.cn 如果第一个看不了,就看其它备用的哦 过年倒计时动画html过年倒计时代码/春节倒计时网页版【春节倒计时html】

Global site tag (gtag.js) - Google Analytics