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;
    }
};
相关推荐
啦啦啦啦啦zzzz1 小时前
数据结构:二叉排序树(递归与非递归函数的全部实现)
数据结构·c++·二叉排序树
memcpy01 小时前
LeetCode 2657. 找到两个数组的前缀公共数组【集合,位运算】中等
算法·leetcode·职场和发展
踩坑记录1 小时前
leetcode 912 排序数组 堆排序
leetcode
计算机安禾1 小时前
【算法分析与设计】第37篇:平面扫描与线段交问题
java·大数据·数据库·算法·机器学习
8Qi81 小时前
LeetCode 236. 二叉树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·lca·后序遍历
兰令水1 小时前
leecodecode【二叉树排序+最近公共祖先】【2026.6.2打卡-java版本】
java·数据结构·算法·leetcode
人道领域1 小时前
【LeetCode刷题日记】77&&216.回溯算法剪枝优化在组合问题中的应用
java·算法·leetcode
Deepoch1 小时前
Deepoc数学大模型:以低幻觉特性护航半导体精准设计与制造
大数据·人工智能·算法·半导体·deepoc
诸葛务农1 小时前
共沸脱水技术及其在光刻胶用PGMEA纯化中的应用(上)
java·数据库·算法