leetcode3633 最早完成陆地和水上游乐设施的时间I

一、问题描述

二、解题思路

本题可以使用暴力枚举的方法来解决,解题思路如下:

(1)遍历陆地项目,固定陆地项目,枚举海洋项目,就是构成一个(i,j)对,i为陆地项目的下标,j为海洋项目的下标;

(2)对于每一个(i,j)对,有先陆地后海洋和先海洋后陆地两种情况:

<1>先陆地后海洋:time1=max(landstart+landduration,waterstart)+waterduration;

<2>先海洋再陆地:time2=max(waterstart+waterduration,landstart)+landduration;

完成全局枚举,ret为最小的time值;

三、代码实现

cpp 复制代码
class Solution {
public:
    int earliestFinishTime(vector<int>& landStartTime, vector<int>& landDuration, vector<int>& waterStartTime, vector<int>& waterDuration) {
        //暴力:对于每一个(i,j)对,分别计算时间,取全局最小值,进行返回
        int ret =INT_MAX;
        for(int i=0;i!=landStartTime.size();i++)
            for(int j=0;j!=waterStartTime.size();j++){
                int landstart=landStartTime[i],landduration=landDuration[i];
                int waterstart=waterStartTime[j],waterduration=waterDuration[j];
                //先陆地再海洋
                int time1=max(landstart+landduration,waterstart)+waterduration;
                //先海洋再陆地
                int time2=max(waterstart+waterduration,landstart)+landduration;
                ret=min(ret,min(time1,time2));
            }
        return ret;
    }
};
相关推荐
To_OC14 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与19 小时前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
博客18001 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴1 天前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
复杂网络1 天前
论最小 Agent 计算机的形态
算法
kisshyshy2 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
众少成多积小致巨2 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
猿人谷2 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络2 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法