2023年厦门市第30届小学生C++信息学竞赛复赛上机操作题(三、2023C. 太空旅行(travel))

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

struct Ship {
    int u; // 从地球到火星的时间
    int v; // 从火星到天王星的时间
};

// 自定义比较函数
bool cmp(const Ship &a, const Ship &b) {
    return a.u + max(a.v, b.u) + b.v < b.u + max(b.v, a.u) + a.v;
}

int main() {
	// 使用 freopen 进行文件输入输出
	//freopen("travel.in", "r", stdin);  // 输入文件
	//freopen("travel.out", "w", stdout); // 输出文件
    int N; // 飞船数量
    cin >> N;
    
    vector<Ship> ships(N);
    
    // 输入飞船的时间数据
    for (int i = 0; i < N; ++i) {
        cin >> ships[i].u >> ships[i].v;
    }
    
    // 使用自定义比较函数进行排序
    sort(ships.begin(), ships.end(), cmp);
    
    // 输出飞船的排序结果 
    /*for (int i = 0; i < N; ++i) {
        cout << ships[i].u << " " << ships[i].v << endl;
    }*/
	
	    
    int earth_departure_time = 0; // 从地球出发的时间
    int mars_departure_time = 0;   // 从火星出发的时间
    int total_time = 0;            // 总时间
    
    // 贪心算法计算总时间
    for (const auto &ship : ships) {
        // 更新从地球出发的时间
        earth_departure_time += ship.u;
        
        // 计算从火星出发的时间
        mars_departure_time = max(earth_departure_time, mars_departure_time) + ship.v;
        
        // 更新总时间为当前飞船到达天王星的时间
        total_time = mars_departure_time;
    }
    
    // 输出最终的总时间
    cout << total_time << endl;

    return 0;
}
相关推荐
Hello--_--World4 分钟前
ES13:类私有属性和方法、顶层 await、at() 方法、Object.hasOwnProperty()、类静态块 相关知识点
开发语言·javascript·es13
cpp_25018 分钟前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-13012312 分钟前
二元一次方程组求解器c++代码
开发语言·c++·算法
weixin_5206498717 分钟前
C#进阶-特性全知识点总结
开发语言·c#
楼田莉子19 分钟前
同步/异步日志系统:日志落地模块\日志器模块\异步日志模块
linux·服务器·c++·学习·设计模式
文祐19 分钟前
C++类之虚函数表及其内存布局
开发语言·c++
小狄同学呀27 分钟前
同样的global,不同的audioLibPath——记一次诡异的内存错位
c++·windows
编程大师哥36 分钟前
C++类和对象
开发语言·c++·算法
M1582276905537 分钟前
工业 CAN 总线无线互联利器|4 路 CAN 转 4G/WiFi 网关 产品介绍
开发语言·php
burning_maple1 小时前
AI 工程实战指南:从零开始构建 AI 应用
开发语言·人工智能