这是一道贪心算法题目。
题目要求用尽量少的矩形海报覆盖给定的N个矩形,并且矩形的宽度均为1。
可以通过贪心算法来解决这个问题。首先将所有矩形按照高度从大到小排序,然后依次枚举每个矩形,如果它未被覆盖,就用一个新的海报覆盖它。这样能保证每次选择的海报高度最小。
C 代码如下
#include<cstdio>
#include<algorithm>
using namespace std;
const int N=250001;
int n,a[N],ans;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
sort(a+1,a+n+1);
int mx=0;
for(int i=1;i<=n;i++){
if(a[i]>mx){
mx=a[i];
ans++;
}
}
printf("%d\n",ans);
return 0;
}