[leetcode/lintcode 题解] 算法面试高频题详解:亮起时间最长的灯

简介: [leetcode/lintcode 题解] 算法面试高频题详解:亮起时间最长的灯

描述
有一排 26 个彩灯,编号从 0 到 25,现在给出了一系列控制指令来控制这些彩灯的开关。
一开始这些彩灯都是关闭的,然后指令将逐条发出。
在每条指令operation[i]中含有两个整数 operationi, operationi。
在接收到一条指令时,标号为 operationi 的彩灯会亮起,直到第 operationi 秒的时候熄灭。
当灯熄灭后,下一条指令将会发出。
其中第一条指令将在第0秒的时候发出,并被立刻执行。
你的任务是找到哪个彩灯单次亮起的时间最长。

1≤n≤1051≤n≤105
0≤keyTimesi≤25(0≤i<n)0≤keyTimesi≤25(0≤i<n)
0≤keyTimesi≤108(0≤i<n)0≤keyTimesi≤108(0≤i<n)
保证至少有一个按键.
保证 keyTimes 是按照 keyTimesi 升序排序的.

在线评测地址:领扣题库官网

样例1
输入:
[[0,2],[1,5],[0,9],[2,15]]
输出:
'c'
说明:
operation = `[[0, 2], [1, 5], [0, 9], [2, 15]]`
在第0秒的时候,接收到指令`[0, 2]`,此时标号为 0 的灯亮起,第 2 秒的时候熄灭。此时 0号灯 的单次亮起时间为`2-0 = 2` 秒。
在第2秒的时候,接收到指令`[1, 5]`,此时标号为 1 的灯亮起,第 5 秒的时候熄灭。此时 1号灯 的单次亮起时间为 `5-2 = 3` 秒。
在第5秒的时候,接收到指令`[0, 9]`,此时标号为 0 的灯亮起,第 9 秒的时候熄灭。此时 0号灯 的单次亮起时间为 `9-5 = 4` 秒。
在第9秒的时候,接收到指令`[2, 15]`,此时标号为 2 的灯亮起,第 15 秒的时候熄灭。此时 2号灯 的单次亮起时间为 `15-9 = 6` 秒。
所以单次亮起的最长时间为 `max(2, 3, 4, 6) = 6` 秒,是标号为 `2` 的彩灯。

**你需要返回一个小写英文字母代表这个编号。`如 'a' 代表 0,'b' 代表 1,'c' 代表 2 ... 'z' 代表 25。`**
所以你的答案应该是`'c'`

算法:模拟
解题思路:
模拟路灯开关的过程,并记录最长的灯亮的时间,以及当前亮起时间最长的灯。
复杂度分析:
时间复杂度:O(n)
n为数组的长度。
空间复杂度:O(1)
代码:

public class Solution {
    /**
     * @param operation: A list of operations.
     * @return: The lamp has the longest liighting time.
     */
    public char longestLightingTime(List<List<Integer>> operation) {
        int maxTime = operation.get(0).get(1);
        char answer = (char)('a' + operation.get(0).get(0));
        int n = operation.size();

        for (int i = 0; i < n - 1; i++) {
            List<Integer> next = operation.get(i + 1);
            List<Integer> current = operation.get(i);
            int time = next.get(1) - current.get(1);
            if (time > maxTime) {
                maxTime = time;
                answer = (char)(next.get(0) + 'a');
            }
        }
        return answer;
    }
}

更多题解参考:九章官网solution
https://www.jiuzhang.com/solution/longest-lighting-time/?utm_source=sc-tianchi-sz-0406

相关文章
|
8天前
|
存储 算法
Leetcode 30天高效刷数据结构和算法 Day1 两数之和 —— 无序数组
给定一个无序整数数组和目标值,找出数组中和为目标值的两个数的下标。要求不重复且可按任意顺序返回。示例:输入nums = [2,7,11,15], target = 9,输出[0,1]。暴力解法时间复杂度O(n²),优化解法利用哈希表实现,时间复杂度O(n)。
19 0
|
14天前
|
存储 缓存 算法
面试遇到算法题:实现LRU缓存
V哥的这个实现的关键在于维护一个双向链表,它可以帮助我们快速地访问、更新和删除最近最少使用的节点,同时使用哈希表来提供快速的查找能力。这样,我们就可以在 O(1) 的时间复杂度内完成所有的缓存操作。哈哈干净利索,回答完毕。
|
25天前
|
算法
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
21 3
|
25天前
|
存储 算法
代码随想录算法训练营第五十九天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
代码随想录算法训练营第五十九天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
22 1
|
25天前
|
算法
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
18 3
|
25天前
|
算法
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
34 1
|
25天前
|
算法
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
24 1
|
26天前
|
算法 API DataX
二叉树(下)+Leetcode每日一题——“数据结构与算法”“对称二叉树”“另一棵树的子树”“二叉树的前中后序遍历”
二叉树(下)+Leetcode每日一题——“数据结构与算法”“对称二叉树”“另一棵树的子树”“二叉树的前中后序遍历”
|
3天前
|
算法 数据安全/隐私保护 计算机视觉
基于二维CS-SCHT变换和LABS方法的水印嵌入和提取算法matlab仿真
该内容包括一个算法的运行展示和详细步骤,使用了MATLAB2022a。算法涉及水印嵌入和提取,利用LAB色彩空间可能用于隐藏水印。水印通过二维CS-SCHT变换、低频系数处理和特定解码策略来提取。代码段展示了水印置乱、图像处理(如噪声、旋转、剪切等攻击)以及水印的逆置乱和提取过程。最后,计算并保存了比特率,用于评估水印的稳健性。
|
4天前
|
存储 算法 数据可视化
基于harris角点和RANSAC算法的图像拼接matlab仿真
本文介绍了使用MATLAB2022a进行图像拼接的流程,涉及Harris角点检测和RANSAC算法。Harris角点检测寻找图像中局部曲率变化显著的点,RANSAC则用于排除噪声和异常点,找到最佳匹配。核心程序包括自定义的Harris角点计算函数,RANSAC参数设置,以及匹配点的可视化和仿射变换矩阵计算,最终生成全景图像。