zoukankan      html  css  js  c++  java
  • P2519-[HAOI2011]problem a

     1 #include <bits/stdc++.h>
     2 #define _for(i,a,b) for(register int i = (a);i < b;i ++)
     3 #define _rep(i,a,b) for(register int i = (a);i > b;i --)
     4 #define INF 0x3f3f3f3f
     5 #define MOD 100000000
     6 #define maxn 150003
     7 #define pb push_back
     8 typedef long long ll;
     9 
    10 using namespace std;
    11 typedef pair<int,int> P;
    12 inline ll read()
    13 {
    14     ll ans = 0;
    15     char ch = getchar(), last = ' ';
    16     while(!isdigit(ch)) last = ch, ch = getchar();
    17     while(isdigit(ch)) ans = (ans << 1) + (ans << 3) + ch - '0', ch = getchar();
    18     if(last == '-') ans = -ans;
    19     return ans;
    20 }
    21 inline void write(ll x)
    22 {
    23     if(x < 0) x = -x, putchar('-');
    24     if(x >= 10) write(x / 10);
    25     putchar(x % 10 + '0');
    26 }
    27 struct line
    28 {
    29     int l;
    30     int r;
    31     int w;
    32     bool operator < (line b)
    33     {
    34         if(r != b.r)
    35             return r < b.r;
    36         return l < b.l;
    37     }
    38 };
    39 int N;
    40 vector<line> v;
    41 map<pair<int,int>,int> m;
    42 int dp[maxn];
    43 int binarysearch(int l, int r, int val)
    44 {
    45     while(l <= r)
    46     {
    47         int mid = (l + r) / 2;
    48         if (v[mid].r < val) 
    49             l = mid + 1;
    50         else 
    51             r = mid - 1;
    52     }
    53     return r;
    54 }
    55 int main()
    56 {
    57     N = read();
    58     _for(i,1,N+1)
    59     {
    60         int a = read();
    61         int b = read();
    62         if(a+b+1>N) continue;
    63         m[{a+1,N-b}] ++;
    64     }
    65     v.pb({});
    66     for(auto p:m)
    67     {
    68         line tmp;
    69         int d = p.first.second-p.first.first+1;
    70         tmp.l = p.first.first;
    71         tmp.r = p.first.second;
    72         tmp.w = min(d,p.second);
    73         v.pb(tmp);
    74     }
    75 
    76     sort(v.begin(),v.end());
    77 
    78     dp[1] = v[1].w;
    79     _for(i,2,v.size())
    80     {
    81         int nxt = binarysearch(1, i-1, v[i].l);
    82         dp[i] = max(dp[i-1], dp[nxt] + v[i].w);
    83     }
    84     write(N-dp[v.size()-1]);
    85     return 0;
    86 }
  • 相关阅读:
    PCA算法的最小平方误差解释
    windows下面安装Python和pip终极教程
    理解C/C++的复杂声明
    C++的特殊预处理定义#、##和#@
    虚拟机中linux系统无法打开原保存的显示器配置解决方法
    Visual C++内存泄露检测—VLD工具使用说明
    C++重载、覆盖与隐藏——转载
    python爬虫实战(二)--------千图网高清图
    Linux常用命令12
    Linux常用命令11
  • 原文地址:https://www.cnblogs.com/Asurudo/p/11628040.html
Copyright © 2011-2022 走看看