USACO历年青铜组真题解析 | 2018年2月Teleportation

绮波课程编程2024-06-09 20:42:56  102

学习C++从娃娃抓起!记录下USACO(美国信息学奥赛)备考青铜组别比赛学习过程中的题目,记录每一个瞬间。

附上汇总贴:

【题目描述】

Farmer John最讨厌的农活是运输牛粪。为了精简这个过程,他制造了一个伟大的发明:便便传送门!与使用拖拉机拖着装满牛粪的大车从一个地点到另一个地点相比,他可以使用便便传送门将牛粪从一个地点瞬间传送到另一个地点。

Farmer John的农场沿着一条长直道路而建,所以他农场上的每个地点都可以简单地用该地点在道路上的位置来表示(相当于数轴上的一个点)。一个传送门可以用两个数x和y表示,被拖到地点x的牛粪可以瞬间传送到地点y,反之亦然。

Farmer John想要将牛粪从地点a运输到地点b,他建造了一个可能对这一过程有所帮助的传送门(当然,如果没有帮助,他也可以不用)。请帮助他求出他需要使用拖拉机运输牛粪的总距离的最小值。

【输入】

输入仅包含一行,为四个用空格分隔的整数:a和b,表示起始地点和结束地点,后面是x和y,表示传送门。所有的位置都是范围为0…100的整数,不一定各不相同。

【输出】

输出一个整数,为Farmer John需要用拖拉机运输牛粪的最小距离。

【输入样例】

【输出样例】

3

【代码详解】

#include using namespace std;int a, b, x, y, ans=0;ifstream filein("teleport.in");ofstream fileout("teleport.out");int main{ filein >> a >> b >> x >> y; // 输入a、b、x和y if (x>y) swap(x, y); // 保证x小于y if (a>b) swap(a, b); // 保证a小于b ans = min(abs(b-a), abs(x-a)+abs(y-b)); // 计算b与a的距离,以及通过传送门的距离(即a->x->y->b)的最小值 fileout << ans << endl; // 打印结果 return 0;}

【运行结果】

转载此文是出于传递更多信息目的。若来源标注错误或侵犯了您的合法权益,请与本站联系,我们将及时更正、删除、谢谢。
https://www.414w.com/read/701379.html
0
随机主题
神光同步 随意调色电脑时间日期不自更新了怎么办?为什么每次开机时间都不对?G1东欧爆种, 不然想晋级都难? 森林狼绅士横扫独行侠不在话下泽连斯基将前往法国说服北约击落俄罗斯导弹, 没收俄国被冻结资产反制说到做到, 中方拉长清单, 外交部宣布出手, 美国政客财路被断世界3大无主之地: 前2块已被私人宣布建国, 最后1块无人敢占领!伊朗一天内解开总统坠机谜团: 原是技术故障, 美国终于放心外媒: 高通的差距拉大了经济到转折点了吗? 聊聊超长国债、存量房收储、15%首付和降利率美股三大指数集体收跌 贵金属板块跌幅居前西康高铁最长桥梁建设取得新进展, 通车后关中陕南一小时内可达卖四千的华为nova11pro是大冤种,一千多就是真香机辽篮夺冠发布会杨导感谢所有人!夸赞新疆主场新疆球迷!外卖小哥看泰山比赛落泪, 王大雷: 我想以最真诚的方式表示感谢希望杨紫火到人尽皆知的时候同时也要平平安安安理会交锋,中俄决议草案被拦下,现场7对7,名单上都不是善茬后来者“卷”上, 荣威D5X DMH技术与性价比齐发力新款捷途X70Plus后悬大变样,四驱版实车即将登场【每日精选】周四精选2串1: 尼美根往绩不落下风 前进之鹰出现慢热迹象KPL春季赛最佳阵容有变? AG300W卖壶神, KPL大瓜: 九尾不打夏季赛五款好玩的动作角色扮演单机游戏哪些下载量高
最新回复(0)