免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 2119 | 回复: 10
打印 上一主题 下一主题

请问有什么方法可以判定两个范围有公共部分? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-01-07 12:57 |只看该作者 |倒序浏览
比如说
范围约定为连续递增的序列,但长度不同

范围 A为  3,4,5,6,7
范围 B为  1,2,3,4
则认为A和B有公共部分(3和4)

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2004-01-07 13:07 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

对于连续的,
排序,
然后比较界值。
对于不连续的,
只要一个一个来了。

论坛徽章:
0
3 [报告]
发表于 2004-01-07 13:10 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

连续是连续的,就是比较边界值的话好象还是有点麻烦,
比如说A范围的长度可能大于,等于和小于范围B三种情况。比较边界值的话好象要写很多个条件表达式

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2004-01-07 13:42 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

如果是连续的,
就将四个值排序,
只要前面的两个值不是同一个集合的界值,
就有交叉。

论坛徽章:
0
5 [报告]
发表于 2004-01-07 14:37 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

设范围是[a,b],[c,d](b>;=a,d>;=c)
判断条件是:
return (c-b)*(d-a)<=0;

论坛徽章:
0
6 [报告]
发表于 2004-01-07 14:58 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

原帖由 "tinywind" 发表:
t;=a,d>;=c)
判断条件是:
return (c-b)*(d-a)<=0;



      

COOL!!!

一时想不出反例,请问tinywind有什么依据吗?或者这种方法被证实过吗?

感谢tinywind以及flw的热心帮助.

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
7 [报告]
发表于 2004-01-07 15:30 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

原帖由 "ohai" 发表:



      

COOL!!!

一时想不出反例,请问tinywind有什么依据吗?或者这种方法被证实过吗?

感谢tinywind以及flw的热心帮助.


很简单的推理呀。两个数 (c-b)*(d-a)<=0; < 0(我们只讨论小于零的情况,等于零的说明c=b嘛)。则说明c-b < 0或d-a < 0,两者不能同时小于零。
你把它们的几种情况列一列,就知道了。

论坛徽章:
0
8 [报告]
发表于 2004-01-07 15:45 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

原帖由 "lenovo" 发表:


很简单的推理呀。两个数 (c-b)*(d-a)<=0; < 0(我们只讨论小于零的情况,等于零的说明c=b嘛)。则说明c-b < 0或d-a < 0,两者不能同时小于零。
你把它们的几种情况列一列,就知道了。



谢谢!!

论坛徽章:
0
9 [报告]
发表于 2004-01-08 09:35 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

后来想想这个判断在数学上没问题,但由于程序中有取值范围的限制还是会造成漏洞,用这个判断就没有问题了:
return max(a,c)<=min(b,d);

论坛徽章:
0
10 [报告]
发表于 2004-01-09 02:01 |只看该作者

请问有什么方法可以判定两个范围有公共部分?

原帖由 "tinywind" 发表:
后来想想这个判断在数学上没问题,但由于程序中有取值范围的限制还是会造成漏洞,用这个判断就没有问题了:
return max(a,c)<=min(b,d);


高手就是不一样,把复杂的问题简单化。
我等小辈什么时候才能出头啊。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP