1324:【例6.6】整数区间
时间限制: 1000 ms 内存限制: 65536 KB
提交数: 7185 通过数: 4260
【题目描述】
请编程完成以下任务:
1.读取闭区间的个数及它们的描述;
2.找到一个含元素个数最少的集合,使得对于每一个区间,都至少有一个整数属于该集合,输出该集合的元素个数。
【输入】
首行包括区间的数目n,1≤n≤10000,接下来的n行,每行包括两个整数a,b,被一空格隔开,0≤a≤b≤10000,它们是某一个区间的开始值和结束值。
【输出】
第一行集合元素的个数,对于每一个区间都至少有一个整数属于该区间,且集合所包含元素数目最少。
【输入样例】
4
3 6
2 4
0 2
4 7
【输出样例】
2
【分析】
算法模型∶给 n个闭区间 [ai, bi],在数轴上选尽量少的点,使每个区间内至少有一个点。
算法:首先按 b1<=b2<=…<=bn 排序。每次标记当前区间的右端点 x,并右移当前区间指针,直到当前区间不包含 x,再重复上述操作。如下图,如果选灰色点,移动到黑色点更优。
【输出样例】
#include <stdio.h>
#define N 10010
struct point
{
int x;
int y;
}a[N],t;
int main()
{
int i,j,x,sum=0,n;
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%d%d",&a[i].x,&a[i].y);
for(i=0;i<n-1;i++) //比较排序
{
for(j=i+1;j<n;j++)
{
if(a[i].y>a[j].y)
{
t=a[i];
a[i]=a[j];
a[j]=t;
}
}
}
x=-1;
for(i=0;i<n;i++)
{
if(x>=a[i].x)
continue; //贪心,如果当前区间包含标记点,就跳过
sum++;
x=a[i].y;
}
printf("%d\n",sum); //更新标记点
return 0;
}