NC106366(Minimizing maximizer )

思路






#include <algorithm>
#include <bitset>
#include <cctype>
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <list>
#include <map> 
#include <queue> 
#include <set>
#include <stack>
#include <string>
#include <typeinfo>
#include <vector>
#define ls o << 1
#define rs o << 1 | 1
using namespace std;
const int maxn = 5e5 + 10;
const int inf = 5e5 + 10;
int s[maxn], t[maxn];
int n, m;
int cost[maxn << 2];
int dp[maxn];//dp[j] 表示从1号位转移到j号位的最小代价
void up(int o){
    cost[o] = min(cost[ls], cost[rs]);
}
void build(int o, int l, int r){
    if(l == r){
        if(l == 1) dp[1] = cost[o] = 0;
        else dp[l] = cost[o] = inf;
        return ;
    }
    int mid = (l + r) / 2;
    build(ls, l, mid);
    build(rs, mid + 1, r);
    up(o);
}
void query(int o, int l, int r, int x, int y, int &ans){
    if(l >= x && y >= r){
        ans = min(ans, cost[o]);
        return ;
    }
    int mid = (l + r) / 2;
    if(mid >= x) query(ls, l, mid, x, y, ans);
    if(y > mid) query(rs, mid + 1, r, x, y, ans);
}
void update(int o, int l, int r, int k, int val){
    if(l == r){
        cost[o] = val;
        return ;
    }
    int mid = (l + r) / 2;
    if(mid >= k) update(ls, l, mid, k, val);
    else update(rs, mid + 1, r, k, val);
    up(o);
}
int main(){
    scanf("%d%d", &n, &m);
    for(int i = 1; i <= m; i++){
        scanf("%d%d", &s[i], &t[i]);
    }
    build(1, 1, n);
    for(int i = 1; i <= m; i++){
        int j = t[i]; int val = inf; query(1, 1, n, s[i], t[i], val);
        if(val + 1 < dp[j]){
            dp[j] = val + 1;
            update(1, 1, n, j, dp[j]);
        }
    }
    printf("%d\n", dp[n]);
    return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-09 16:15
我应届生,去年10月份开始在这家公司实习,到今年10月份正好一年想(实习+试用期),在想要不要提前9月份就离职,这样好找工作些,但又差一个月满一年,又怕10月份国庆回来离职,容易错过了下半年的金九银十,到年底容易gap到年后
小破站_程序员YT:说这家公司不好吧,你干了快一年 说这家公司好吧,你刚毕业就想跑路说你不懂行情吧,你怕错过金九银十说 你懂行情吧,校招阶段在实习,毕业社招想换工作 哥们,我该怎么劝你留下来呢
应届生,你找到工作了吗
点赞 评论 收藏
分享
07-09 18:28
门头沟学院 Java
写着提前批,结果还要实习4个月以上???
程序员牛肉:这种不用看,直接投了,面试的时候问对应的HR就行。有可能他们是直接复制的暑期实习的模板。
点赞 评论 收藏
分享
06-12 16:00
天津大学 Java
牛客30236098...:腾讯坏事做尽,终面挂是最破防的 上次被挂了后我连简历都不刷了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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