• LeetCode 2251. 花期内花的数目:排序 + 二分


    【LetMeFly】2251.花期内花的数目:排序 + 二分

    力扣题目链接:https://leetcode.cn/problems/number-of-flowers-in-full-bloom/

    给你一个下标从 0 开始的二维整数数组 flowers ,其中 flowers[i] = [starti, endi] 表示第 i 朵花的 花期 从 starti 到 endi (都 包含)。同时给你一个下标从 0 开始大小为 n 的整数数组 persons ,persons[i] 是第 i 个人来看花的时间。

    请你返回一个大小为 n 的整数数组 answer ,其中 answer[i]是第 i 个人到达时在花期内花的 数目 。

     

    示例 1:

    输入:flowers = [[1,6],[3,7],[9,12],[4,13]], persons = [2,3,7,11]
    输出:[1,2,2,2]
    解释:上图展示了每朵花的花期时间,和每个人的到达时间。
    对每个人,我们返回他们到达时在花期内花的数目。
    

    示例 2:

    输入:flowers = [[1,10],[3,3]], persons = [3,3,2]
    输出:[2,2,1]
    解释:上图展示了每朵花的花期时间,和每个人的到达时间。
    对每个人,我们返回他们到达时在花期内花的数目。
    

     

    提示:

    • 1 <= flowers.length <= 5 * 104
    • flowers[i].length == 2
    • 1 <= starti <= endi <= 109
    • 1 <= persons.length <= 5 * 104
    • 1 <= persons[i] <= 109

    方法一:排序 + 二分

    将所有的开花时间放入一个数组并从小到大排序;将所有的闭花时间也放入一个数组并从小到大排序。

    对于某个时刻(某一天),当前盛开的花朵的数量为: 开花时间小于等于当前时间的花数 − 闭花小于等于当前时间前一天的花数 开花时间小于等于当前时间的花数 - 闭花小于等于当前时间前一天的花数 开花时间小于等于当前时间的花数闭花小于等于当前时间前一天的花数

    如何快速得到非降序数组 a a a ≤ k \leq k k的元素的个数?二分即可。(C++的upper_bound / Python的bisect_right)

    • 时间复杂度 O ( ( n + m ) log ⁡ n ) O((n + m)\log n) O((n+m)logn),其中 n = l e n ( f l o w e r s ) n = len(flowers) n=len(flowers) m = l e n ( p e o p l e ) m = len(people) m=len(people)
    • 空间复杂度 O ( n ) O(n) O(n),力扣返回值不计入算法空间复杂度

    AC代码

    C++
    class Solution {
    public:
        vector<int> fullBloomFlowers(vector<vector<int>>& flowers, vector<int>& people) {
            vector<int> start(flowers.size()), end(flowers.size()), ans(people.size());
            for (int i = 0; i < flowers.size(); i++) {
                start[i] = flowers[i][0];
                end[i] = flowers[i][1];
            }
            sort(start.begin(), start.end());
            sort(end.begin(), end.end());
    
            for (int i = 0; i < people.size(); i++) {
                // 到这一天为止的开花总数 - 到这一天的前一天为止的闭花总数
                int hanagasaku = upper_bound(start.begin(), start.end(), people[i]) - start.begin();  // 花が咲く(はながさく)
                int hanagatiru = upper_bound(end.begin(), end.end(), people[i] - 1) - end.begin();//  花が散る(はながちる)
                ans[i] = hanagasaku - hanagatiru;
            }
            return ans;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    Python

    真简!

    # from typing import List
    # from bisect import bisect_right
    
    class Solution:
        def fullBloomFlowers(self, flowers: List[List[int]], people: List[int]) -> List[int]:
            start = sorted([f[0] for f in flowers])
            end = sorted([f[1] for f in flowers])
            return [bisect_right(start, p) - bisect_right(end, p - 1) for p in people]
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    同步发文于CSDN,原创不易,转载经作者同意后请附上原文链接哦~
    Tisfy:https://letmefly.blog.csdn.net/article/details/133378624

  • 相关阅读:
    【Java编程进阶】常量变量及作用域
    Sentinel
    Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行(含系列目录)。
    <爆>2022中文版-《海外博士申请指南-材料准备、时间线、套磁、面试及录取》免费分享
    docker 开发编译环境搭建
    javascript利用xhr对象实现http流的comet轮循,主要是利用readyState等于3的特点
    Cadence Allegro DXF结构图的导入详细教程
    分库分表如何进行极致的优化
    Mybatis---resultMap详解
    STM32在STM32CubeIDE平台下的RT-Thread Nano移植
  • 原文地址:https://blog.csdn.net/Tisfy/article/details/133378624