当前位置:首页 > 题解目录 > 正文内容

【题解】Ride to Office

亿万年的星光4个月前 (02-14)题解目录1002

【题目描述】

起点与终点相隔4500米。现Charley 需要从起点骑车到终点。但是,他有个习惯,沿途需要有人陪伴,即以相同的速度, 与另外一个人一起骑。而当他遇到以更快的速度骑车的人时,他会以相应的速度跟上这个更快的人。先给定所有与Charley 同路的人各自的速度与出发时间,问Charley 以这种方式跟人,骑完4500米需要多少时间。得出的结果若是小数,则向上取整。

【输入描述】

输入若干组数据,每组数据第一行n(1≤n≤10000),n为0,表示输入结束,接着输入n行数据,每行2个数据,表示速度v和出发时间t,如果t<0,表示陪伴人提早出发了。

【输出描述】

输出对应若干行数据,每行输出1个数,表示最快到达的时间。

【样例输入】

4
20 0
25 -155
27 190
30 240
2
21 0
22 34
0

【样例输出】

780
771

【题目分析】


题目比较坑的一点是速度的单位问题,常见的速度单位是m/s或者是km/h
如果 Charley 的速度是 20 m/s,则骑行 4500 米所需时间为 225 秒,与样例输出不符。

如果 Charley 的速度是 20 km/h(约 5.556 m/s),则骑行 4500 米所需时间约为 810 秒,接近样例输出


所以要进行相应的转换,

基于贪心思路:

  1. 理解题意

    • Charley 需要从起点骑车到终点,距离为4500米。

    • 他需要有人陪伴,且会跟随速度更快的人。

    • 给定n个陪伴者的速度和出发时间,计算Charley完成4500米所需的时间。

  2. 关键点

    • Charley的速度会跟随最快的人。

    • 陪伴者的出发时间可能早于或晚于Charley的出发时间。

    • 计算Charley到达终点的时间,需要考虑所有陪伴者的影响。

  3. 算法步骤

    • 对于每个陪伴者,计算他们到达终点的时间。

    • Charley的到达时间取决于最快陪伴者的到达时间。

    • 遍历所有陪伴者,找到最快到达时间。

【参考答案】

#include <iostream>
#include <cmath>

using namespace std;

int main() {
    int n;
    while (cin >> n && n != 0) {
        int minTime = 1e9;
        for (int i = 0; i < n; ++i) {
            int v, t;
            cin >> v >> t;
            if (v <= 0) continue; // 速度必须大于0
            // 计算到达时间
            if(t>=0){
                double time = ceil((4.5/v*3600) +t);  //注意速度单位
            if (time < minTime) {
                minTime = time;
            }
            }
        
        }
        cout << minTime << endl;
    }
    return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

【题解】东哥的杯子

【题解】东哥的杯子

【题目描述】话说在一场牛客练习赛中,东哥力压群雄,挣得第一,牛客为了奖励东哥的发挥,送他一个马克杯。奖励的马克杯是一个标准的圆台形状,它的上底为R1,下底为R2,高为H, 东哥向杯子里倒V毫升的水,你...

八皇后2

【题目描述】会下国际象棋的人都很清楚:皇后可以在横、竖、斜线上不限步数地吃掉其他棋子。如何将8个皇后放在棋盘上(有8 × 8个方格),使它们谁也不能被吃掉!这就是著名的八皇后问题。对于某个满足要求的8...

【题解】使每位学生都有座位的最少移动次数

【题目描述】一个房间里有 n 个 空闲 座位和 n 名 站着的 学生,房间用一个数轴表示。给你一个长度为 n&...

质数环

【题目描述】有一个整数n,把从1到n的数字无重复的排列成环,且使每相邻两个数(包括首尾)的和都为素数,称为素数环。为了简便起见,我们规定每个素数环都从1开始。例如,下面就是6的一个素数环。1 4 3...

【题解】怪盗基德的滑翔翼

【题解】怪盗基德的滑翔翼

【题目描述】怪盗基德是一个充满传奇色彩的怪盗,专门以珠宝为目标的超级盗窃犯。而他最为突出的地方,就是他每次都能逃脱中村警部的重重围堵,而这也很大程度上是多亏了他随身携带的便于操作的滑翔翼。有一天,怪盗...

【题解】分发饼干

【题目描述】假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;...