上数学课时,老师给了LYH一些闭区间,让他取尽量少的点,使得每个闭区间内至少有一个点。但是这几天LYH太忙了,你们帮帮他吗?
4 1 5 2 4 1 4 2 3 3 1 2 3 4 5 6 1 2 2
1 3 1
好久没有刷题了,过个年简单题都想了半天,其实这就是一个简单的贪心题目:
先排序一下,直接按开始的点排序,然后进行判断点
1.如果下一个区间的点和第一个有交集的话,然后再判断一下,末尾点是不是在这个区间内,选取最小的末尾点,以便于形成最小的区间;
2.如果没有区间的话,则新的点就产生了 ,需要重新建立一个共同区间;
排序的这一方面,改成快速排序效果更好,关键是要理解这一种方法;
AC代码如下:
1 #include<iostream> 2 #include<cstdio> 3 #include<algorithm> 4 #include<cstring> 5 #include<string> 6 #include<cmath> 7 #include<map> 8 using namespace std; 9 int main() 10 { 11 int i,j,k,t,m,n; 12 int a[110],b[101]; 13 while(cin>>t) 14 { 15 int ans=0; 16 for(i=0;i<t;i++) 17 scanf("%d %d",&a[i],&b[i]); 18 for(j=0;j<t-1;j++) 19 for(k=0;k<t-j-1;k++) 20 if(a[k]>a[k+1]) 21 { 22 m=a[k];a[k]=a[k+1];a[k+1]=m; 23 n=b[k];b[k]=b[k+1];b[k+1]=n; 24 } 25 // for(i=0;i<t;i++) 26 // printf("%d %d\n",a[i],b[i]); 27 m=a[0];n=b[0]; 28 for(i=1;i<t;i++) 29 if(a[i]<=n) 30 { 31 if(b[i]<n) 32 n=b[i]; 33 } 34 else 35 {ans++;n=b[i];} 36 printf("%d\n",ans+1); 37 } 38 return 0; 39 }
原文:http://www.cnblogs.com/lovychen/p/3541629.html