• 1109. 航班预订统计


    有一份航班预订表 bookings ,表中第 i 条预订记录 bookings[i] = [firsti, lasti, seatsi] 意味着在从 firsti 到 lasti (包含 firsti 和 lasti )的 每个航班 上预订了 seatsi 个座位。

    请你返回一个长度为 n 的数组 answer,里面的元素是每个航班预定的座位总数。

    示例 1:

    输入:bookings = [[1,2,10],[2,3,20],[2,5,25]], n = 5
    输出:[10,55,45,25,25]
    解释:
    航班编号        1   2   3   4   5
    预订记录 1 :   10  10
    预订记录 2 :       20  20
    预订记录 3 :       25  25  25  25
    总座位数:      10  55  45  25  25
    因此,answer = [10,55,45,25,25]
    

    示例 2:

    输入:bookings = [[1,2,10],[2,2,15]], n = 2
    输出:[10,25]
    解释:
    航班编号        1   2
    预订记录 1 :   10  10
    预订记录 2 :       15
    总座位数:      10  25
    因此,answer = [10,25]
    

    提示:

    • 1 <= n <= 2 * 104
    • 1 <= bookings.length <= 2 * 104
    • bookings[i].length == 3
    • 1 <= firsti <= lasti <= n
    • 1 <= seatsi <= 104

    vector corpFlightBookings(vector>& bookings, int n)
    {
        vectorret(n, 0);

        //差分数组
        for (int i = 0; i < bookings.size(); i++)
        {
            int start = bookings[i][0];
            int end = bookings[i][1];
            ret[start-1] +=  bookings[i][2];//开始
            if (end < n)
            {
                ret[end] -= bookings[i][2];//截止
            }
        }

        //前缀和
        for (int i = 1; i < n; i++)
        {
            ret[i] += ret[i - 1];
        }
        return ret;
    }

  • 相关阅读:
    每日一练 | 华为认证真题练习Day114
    Spring之依赖注入源码解析
    Android 11.0 Launcher3去掉抽屉模式 双层改成单层(一)
    10分钟带你入门chrome(谷歌)浏览器插件开发
    mosaic实现
    SpringMVC多文件上传
    ACA-PEG-SH 丙烯酰胺PEG巯基
    Java项目:工艺品商城系统(java+SSM+JSP+bootstrap+Mysql)
    云原生架构
    一些 dp 题
  • 原文地址:https://blog.csdn.net/yinhua405/article/details/127400072