P3028 汽水机(差分)

题目

P3028 [USACO10OCT]汽水机Soda Machine

解析

差分,看到\(a[i]\leq 1e9\),离散化一下,在\(l\)\(+1\)\(r+1\)\(-1\),这样就只有\(2n\)个点了,再按位置排一下序,扫一遍记录答案就可以了。
需要注意的是,如果在某个位置既有\(+1\)操作又有\(-1\)操作,要先\(-1\)\(+1\),否则在统计答案的时候会多算

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 1e6 + 10;

int sum, ans, n;

struct node {
    int pos, val;
    bool operator<(const node & oth) const {
        return pos == oth.pos ? val < oth.val : pos < oth.pos;
    }
} e[N];

int main() {
    ios::sync_with_stdio(false);
    cin >> n;
    for (int i = 1, x, y; i <= n; ++i) {
        cin >> x >> y;
        e[i] = (node) {x, 1}, e[i + n] = (node) {y + 1, -1};
    }
    sort(e + 1, e + 1 + n + n);
    for (int i = 1; i <= n + n; ++i) {
        sum += e[i].val;
        ans = max(ans, sum);
    }
    cout << ans;
}

全部评论

相关推荐

07-11 22:27
中南大学 Java
程序员牛肉:学历的话没问题。但是没问题的也就只有学历了。 其实你的整体架构是正确的,博客接着干。但是项目有点过于简单了。从后端的角度上讲,你这也就是刚入门的水平,所以肯定约面试够呛。 如果你要应聘后端岗位,那你第一个项目竟然是仿写操作系统。这个你要面试官咋问你。你一定要记住一点,你简历上写的所有的东西,都是为了证明你有能力胜任当前的岗位,而不是为了证明你自己会什么。 如果你只是浅浅的做几个项目,描述也都是烂大街。技术点也都是各种混水类的配置类需求,那你就不要幻想自己能走多远。一定要保持思考,保持学习。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务