C++,Migrated from Lutece 300 木杆上的蚂蚁

news/2025/3/12 19:15:32/文章来源:https://www.cnblogs.com/l25428455/p/18768298
/*
Migrated from Lutece 300 木杆上的蚂蚁
Description
在一根细木杆上,有一些速度相同蚂蚁,它们有的往左走,有的往右走,木杆很细,只允许一只蚂蚁通过,所以当两只蚂蚁碰头的时候,它们会掉头继续前进,直到走出边界,掉下木杆。已知木杆的长度和每只蚂蚁的名字、位置和初始方向,问依次掉下木杆的蚂蚁花费的时间以及它的名字。Input
输入包含多组测试数据。第一行包含一个整数
T(T≤20),代表测试数据组数。
每组测试数据的第一行包含两个整数
N, L,表示有N只蚂蚁(N≤100),木杆长度为L(L≤1000)。假设蚂蚁每秒前进一个单位距离,掉头转向的时间忽略不计。
以下N行,每行依次为蚂蚁的名字(长度不超过10,仅由英文字母组成),初始位置
p(0<p<L,整数,表示蚂蚁离木杆最左端的距离),初始方向(一个字符,L表示向左,R表示向右),以单个空格分隔,数据保证初始不会有两只蚂蚁在同一个位置。
Output
对于第k组测试数据,首先输出一行为Case #k:。
然后输出N行,给出依次掉下木杆的蚂蚁花费的时间以及它的名字,以单个空格分隔。 (按照掉下木杆的先后顺序输出,数据保证不会有两支蚂蚁同时掉下木杆)。Samples
*/
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
//记录蚂蚁的名字和位置
struct Ant{std::string name;int pos;bool operator<(const Ant& other) const{return pos<other.pos;}
};
//记录蚂蚁掉落的时间和掉落的方向
struct DropTimeAndDropSide{int time;bool fallsLeft;bool operator<(const DropTimeAndDropSide& other) const{return time<other.time;}
};
void solve(int caseNo){int antCount,rodLength;std::cin>>antCount>>rodLength;//rod,竿std::vector<Ant> ants(antCount);std::vector<DropTimeAndDropSide> times(antCount);for(int i = 0;i<antCount;++i){std::cin>>ants[i].name;int pos;char dir;std::cin>>pos>>dir;       ants[i].pos=pos;if(dir=='L'){times[i].time = pos;times[i].fallsLeft=true;}else{times[i].time = rodLength-pos;times[i].fallsLeft=false;}}//无论怎么移动, 蚂蚁之间的相对位置是不会变化的, 下一个掉落的一直都是在最左边或者最右边的蚂蚁//将蚂蚁按照位置排序, 以获取最左边和最右边的蚂蚁std::sort(ants.begin(),ants.end());//位置在最左边的蚂蚁掉落的时间取决于方向向左的蚂蚁中位置最左边的蚂蚁//->--<-------<;--<>------<--;<---->--<----; // a  b//a会掉落,但是掉落的时间取决于b的位置//位置在最右边的蚂蚁掉落的时间取决于方向向右的蚂蚁中位置最右边的蚂蚁//下一个掉落的蚂蚁是左边的蚂蚁还是右边的蚂蚁取决于最左边向左的蚂蚁和最右边向右的蚂蚁哪个离端点近std::sort(times.begin(),times.end());int leftIndex = 0,rightIndex = antCount-1;std::cout<<"Case #"<<caseNo<<": "<<std::endl;for(const auto& time : times){if(time.fallsLeft){std::cout<<time.time<<' '<<ants[leftIndex++].name<<std::endl;}else{std::cout<<time.time<<' '<<ants[rightIndex--].name<<std::endl;}}
}
int main(){int T;std::cin>>T;for(int i = 1;i<=T;++i){solve(i);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/897818.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CTFHUB

CTFHUB hidden 打开题目为一张图片老规矩,查看属性等,并无异常,用010打开,发现隐藏zip文件手动分离,发现带密码,不是zip伪密码,爆破得到解压得到一张图片,二维码,但是少了一部分,猜测是否是crc校验,用010用脚本,得到正确的尺寸最后通过扫二维码得到flag

Ubuntu系统怎么选择使用指定内核启动

环境查看 系统环境No LSB modules are available. Distributor ID:Ubuntu Description:Ubuntu 22.04.4 LTS Release:22.04 Codename:jammy g@xiaoxing-MS-7D22:~$ uname -a Linux xiaoxing-MS-7D22 5.15.0-134-generic #145-Ubuntu SMP Wed Feb 12 20:08:39 UTC 2025 x86_64 x8…

002Axios网络请求的封装

在日常应用过程中,一个项目中的网络请求会很多,此时一般采取的方案是将网络请求封装起来 创建项目npm create vite@latest 起个名字axiospro02 选择 选择 进入文件夹 打开看一下没问题 这个样式删掉 这句话删掉 这页这样写 这页这样写 1、安装 axios:npm install axios;…

【PHP攻防】带有 LFI 和 SSH 日志中毒的 RCE

免责声明 此文所提供的信息只为网络安全人员对自己所负责的网站、服务器等(包括但不限于)进行检测或维护参考,未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作。利用此文所提供的信息而造成的直接或间接后果和损失,均由使用者本人负责。本文所提供的工具仅用…

【最佳方案】RAG 技术深度剖析及 MaxKB 在企业 AI 落地中的应用策略

RAG 已经成为 LLM 大语言模型在企业落地的最佳方案,其中主要是因为 RAG 能够解决幻觉问题、时效性问题以及数据安全问题。解决幻觉问题:LLM 文本生成的底层原理是基于概率的 token by token 的形式,因此会不可避免地产生“一本正经的胡说八道"的情况。比如:你说,”博…

开源中国完成数亿元 C 轮融资:Gitee 加速智能化研发效能革新

开源中国近日宣布完成数亿元C轮融资,由北京信息产业发展投资基金领投,深报一本及上河动量跟投。本轮资金将用于加速Gitee在AI DevSecOps领域的创新,构建智能化研发效能解决方案,提升企业级用户的研发效率与安全性。目前,Gitee已服务36万企业用户,在金融、能源、政府等核心…

【ArcGIS】从数据导入到开始标注

1.点击 新建工程下面的地图2.找一个合适的位置新建项目3.右键地图,点击添加数据找到下载好的数据后点确认4.打开后图像会自动和地图对准,不用管5.下载群里的中印.ecs,在桌面找一个文件夹保存(不然可能在软件里找不到) 点击这里的浏览至现有方案,找到ecs文件会出现下面这五…

Windows 提权-内核利用_2

本文通过 Google 翻译 Kernel Exploits Part 2 – Windows Privilege Escalation 这篇文章所产生,本人仅是对机器翻译中部分表达别扭的字词进行了校正及个别注释补充。导航0 前言 1 新版 Windows 系统内核利用 2 搜寻内核漏洞2.1 枚举内核利用 - 手动 2.2 枚举内核利用 - 自动…

90%的开发者都忽略的文本向量化技巧!

1 啥是文本张量表示? 将一段文本使用张量表示,一般将词汇表示成向量,称作词向量,再由各个词向量按序组成矩阵形成文本表示,如: ["人生", "该", "如何", "起头"]==># 每个词对应矩阵中的一个向量 [[1.32, 4,32, 0,32, 5.2],[3…

北京大学!121页,讲透DeepSeek的私有化部署!(免费下载)

北京大学肖睿团队发布的《DeepSeek私有化部署技术白皮书》,系统揭示了国产大模型从实验室走向产业落地的完整路径。这份文档的核心价值,在于打破“私有化部署=高性能硬件堆砌”的固有认知,提出一套覆盖个人电脑、边缘设备到企业级集群的弹性部署体系。北京大学肖睿团队发布的…

网易伏羲人工智能实验室技术创新再突破!前馈捏脸等3篇论文入选CVPR 2025

近日,全球计算机视觉和模式识别领域的顶级会议CVPR (Conference on Computer Vision and Pattern Recognition)公布论文接收结果:网易伏羲人工智能实验室凭借其在前馈捏脸等领域的创新研究,成功入选3篇论文。CVPR 是计算机视觉和模式识别领域最顶级的学术会议之一,至今已…

html的基础操作2

1、表格标签(table语句) (1)认识表中的一些常用单词 border 边距 align 格式 ‘ center’ 对齐 cellspacing 单元格与单元格的距离 cellpadding 单元格与内容的距离 wedth 宽度 height 高度 tr 表示:行 th 表示:表头 td :表示列 -表格的案例--代码- <!DOCTYPE…