信息学奥赛一本通(1324:【例6.6】整数区间)

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;
}

http://ybt.ssoier.cn:8088/problem_show.php?pid=1324

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值