整数区间

简介: 整数区间请编程完成以下任务:   1.从文件中读取闭区间的个数及它们的描述;   2.找到一个含元素个数最少的集合,使得对于每一个区间,都至少有一个整数属于该集合,输出该集合的元素个数。 【输入】 首行包括区间的数目n,1

整数区间
请编程完成以下任务:   
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,再重复上述操作。
•如下图,如果选灰色点,移动到黑色点更优。

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 struct section
 4 {
 5     int begin,end;
 6 };
 7 int cmp(const void *x,const void *y)
 8 {
 9     int ans1=(*(struct section *)x).end - (*(struct section *)y).end;
10     if(ans1>0) return 1;
11     else if(ans1<0) return -1;
12     else 
13     {
14         ans1=(*(struct section *)y).begin - (*(struct section *)x).begin;
15         return ans1;
16     }
17 }
18 int main()
19 {
20     freopen("a.in","r",stdin);
21     freopen("a.out","w",stdout);
22     struct section *a;
23     int *b;
24     int n,i;
25     int lastEnd;
26     int count;
27     
28     scanf("%d",&n);
29     a=(struct section *)malloc(n*sizeof(struct section));
30     b=(int *)malloc(n*sizeof(int));
31     
32     for(i=0;i<n;i++)
33     {
34         scanf("%d%d",&a[i].begin,&a[i].end);
35         b[i]=-1;
36     }
37     qsort(a,n,sizeof(struct section),cmp);
38     
39     lastEnd=-1;
40     count=0;
41     for(i=0;i<n;i++)
42     {
43         if(lastEnd>=a[i].begin) continue;
44         count++;
45         lastEnd=a[i].end;
46         b[count-1]=lastEnd;
47     }
48     /*for(i=0;i<count;i++)
49         printf("%d\n",b[i]);*/
50     printf("%d\n",count);
51     free(a);
52     free(b);
53     return 0;
54 }

 

相关文章
|
算法 定位技术 数据安全/隐私保护
简谈百度坐标反转至WGS84的三种思路
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 基于百度地图进行数据展示是目前项目中常见场景,但是因为百度地图是基于BD09坐标系的,GPS坐标(WGS84)或者其他常见的标准坐标是无法准确在地图上进行展示的,但是互联网在线情况下,百度提供了将WGS84经纬度转换成百度经纬度坐标的API,这里不再对其进行研究(离线情况下也有专门方法解决)。
1933 0
|
XML 编译器 数据格式
基于XML的自动装配~
基于XML的自动装配~
112 0
基于XML的自动装配~
|
缓存 运维 监控
shell监控系统状态和资源使用命令
shell监控系统状态和资源使用命令
348 2
|
Python
【信号处理】python按原理实现BPSK、QPSK、QAM信号调制
本文提供了两种不同的方法来实现16-QAM(正交幅度调制)的调制和解调过程,一种是使用commpy库,另一种是通过手动定义映射字典来实现。
976 8
|
存储 C语言
【C语言刷题系列】对数字添加逗号
【C语言刷题系列】对数字添加逗号
|
机器学习/深度学习 编解码 算法
【博士每天一篇文-算法】Spatially embedded recurrent neural networks reveal widespread links between
本文介绍了空间嵌入循环神经网络(seRNNs)的研究,揭示了结构和功能神经科学发现之间的联系,并展示了seRNNs如何在面临资源限制的同时,通过优化其结构拓扑来解决任务并表现出生物大脑类似的模块化和小世界特性。
108 1
【博士每天一篇文-算法】Spatially embedded recurrent neural networks reveal widespread links between
|
存储 Oracle 关系型数据库
Typora+PicGo+super-prefix+阿里云OSS设置图床
Typora+PicGo+super-prefix+阿里云OSS设置图床
|
机器学习/深度学习 自然语言处理 数据挖掘
【LangChain系列】第七篇:工作流(链)简介及实践
【5月更文挑战第21天】LangChain是一个框架,利用“链”的概念将复杂的任务分解为可管理的部分,便于构建智能应用。数据科学家可以通过组合不同组件来处理和分析非结构化数据。示例中展示了如何使用LLMChain结合OpenAI的GPT-3.5-turbo模型,创建提示模板以生成公司名称和描述。顺序链(SimpleSequentialChain和SequentialChain)则允许按顺序执行多个步骤,处理多个输入和输出
2369 1
|
运维 监控 安全
Shell实现钉钉机器人定时消息通知
Shell实现钉钉机器人定时消息通知
430 0
|
人工智能 安全 前端开发
Spring Security系列教程13--基于过滤器实现图形验证码
前言 在前两个章节中,一一哥 带大家学习了Spring Security内部关于认证授权的核心API,以及认证授权的执行流程和底层原理。掌握了这些之后,对于Spring Security,我们不仅做到了 "知其然",而且也做到了 "知其所以然"! 在现在的求职环境下,只知道某个技能点的用法是远远不够的,面试官会要求我们研究某个技术的底层实现原理,所以虽然前面的两章内容掌握起来很有难度,但是还是希望各位小伙伴结合源码认真研读,这样你才能在编程之路上走的更远更高! 总是研究底层,对于我们初学者来说,既有难度,也会影响咱们的学习积极性,所以从本篇文章开始,咱们继续学习Spring Securit
494 0