欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!
专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。
适合人群:
- 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
- 希望系统学习C++/Python编程的初学者
- 想要提升算法与编程能力的编程爱好者
附上汇总贴:USACO历年青铜组真题解析 | 汇总-优快云博客
【题目描述】
Farmer John最讨厌的农活是运输牛粪。为了精简这个过程,他制造了一个伟大的发明:便便传送门!与使用拖拉机拖着装满牛粪的大车从一个地点到另一个地点相比,他可以使用便便传送门将牛粪从一个地点瞬间传送到另一个地点。
Farmer John的农场沿着一条长直道路而建,所以他农场上的每个地点都可以简单地用该地点在道路上的位置来表示(相当于数轴上的一个点)。一个传送门可以用两个数x和y表示,被拖到地点x的牛粪可以瞬间传送到地点y,反之亦然。
Farmer John想要将牛粪从地点a运输到地点b,他建造了一个可能对这一过程有所帮助的传送门(当然,如果没有帮助,他也可以不用)。请帮助他求出他需要使用拖拉机运输牛粪的总距离的最小值。
【输入】
输入仅包含一行,为四个用空格分隔的整数:a和b,表示起始地点和结束地点,后面是x和y,表示传送门。所有的位置都是范围为0…100的整数,不一定各不相同。
【输出】
输出一个整数,为Farmer John需要用拖拉机运输牛粪的最小距离。
【输入样例】
3 10 8 2
【输出样例】
3
【代码详解】
#include <bits/stdc++.h>
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;
}
【运行结果】
3 10 8 2
3