给定 NN 个闭区间 [ai,bi][ai,bi],请你在数轴上选择尽量少的点,使得每个区间内至少包含一个选出的点。
输出选择的点的最小数量。
位于区间端点上的点也算作区间内。
输入格式
第一行包含整数 NN,表示区间数。
接下来 NN 行,每行包含两个整数 ai,biai,bi,表示一个区间的两个端点。
输出格式
输出一个整数,表示所需的点的最小数量。
数据范围
1≤N≤1051≤N≤105,
 −109≤ai≤bi≤109−109≤ai≤bi≤109
输入样例:
3
-1 1
2 4
3 5
输出样例:
2#include<bits/stdc++.h>
 using namespace std;
 const int N=1e6+10; 
 struct jb{ 
     int l,r;
     bool operator<(const jb &w)const
     { 
         return r<w.r;
     }
     
 }range[N]; 
 int main ()
 { 
     int n;
     scanf("%d",&n);
     for(int i=0;i<n;i++)
     { 
         scanf("%d%d",&range[i].l,&range[i].r);
     }
     sort(range,range+n);
     int res=0;
     int end=INT_MIN;
     for(int i=0;i<n;i++)
     { 
         if(end<range[i].l)
         { 
             res++;
             end=range[i].r;
         }
     }
     cout<<res<<endl;
     return 0;
 }