免费注册 查看新帖 |

Chinaunix

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

计算投影总长度 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-06-09 20:37 |只看该作者 |倒序浏览
A    5    10
A    15    18
A    2    7
A    4    6
B    1    10
B    3    5
C    1    3
C    4    5
C    11    13

如上,第一列为标签(列间以tab分隔),其后两列可以看成是x轴上一条线段的两个端点,计算相同标签下线段的投影总长度(即不计算重叠的部分)。

以标签A为例:

最终A标签下线段投影总长度为10-2+18-15=11。

请大侠们指点一下怎么编程序解决吧。

谢谢啦^_^

论坛徽章:
78
双子座
日期:2013-10-15 08:50:09天秤座
日期:2013-10-16 18:02:08白羊座
日期:2013-10-18 13:35:33天蝎座
日期:2013-10-18 13:37:06狮子座
日期:2013-10-18 13:40:31双子座
日期:2013-10-22 13:58:42戌狗
日期:2013-10-22 18:50:04CU十二周年纪念徽章
日期:2013-10-24 15:41:34巨蟹座
日期:2013-10-24 17:14:56处女座
日期:2013-10-24 17:15:30双子座
日期:2013-10-25 13:49:39午马
日期:2013-10-28 15:02:15
2 [报告]
发表于 2011-06-09 21:44 |只看该作者
分情况一个个算?

论坛徽章:
0
3 [报告]
发表于 2011-06-09 21:49 |只看该作者
回复 2# yybmsrs


    嗯,得考虑到每一种情况,思路有点儿乱,谢谢参与

论坛徽章:
0
4 [报告]
发表于 2011-06-09 22:15 |只看该作者
没严格测试,你看看是否正确。
  1. #!/usr/bin/perl

  2. use strict;
  3. use warnings;

  4. my %result;
  5. while (<DATA>) {
  6.         my ($key,$start,$end) = split /\s+/;
  7.          foreach ($start+1 .. $end) {
  8.                  $result{$key}{'count'}++ unless ($result{$key}{$_});
  9.                  $result{$key}{$_} = 1;
  10.          }
  11. }
  12. foreach (keys %result) {
  13.         print "$_\t$result{$_}{'count'}\n";
  14. }

  15. <STDIN>;

  16. __DATA__
  17. A    5    10
  18. A    15    18
  19. A    2    7
  20. A    4    6
  21. B    1    10
  22. B    3    5
  23. C    1    3
  24. C    4    5
  25. C    11    13
复制代码

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
5 [报告]
发表于 2011-06-09 22:29 |只看该作者
A 并 B = A + B - (A 交 B) 这个公式叫什么来着?可以用

论坛徽章:
0
6 [报告]
发表于 2011-06-09 22:31 |只看该作者
回复 4# iamlimeng


    刚试了下,可以的,谢谢了
    我再好好研究研究,呵呵

论坛徽章:
0
7 [报告]
发表于 2011-06-09 22:34 |只看该作者
回复 5# zhlong8


    嗯。对于两个的情况还行,多个并集可能实现起来有点儿麻烦。谢谢提供思路

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
8 [报告]
发表于 2011-06-09 22:36 |只看该作者
回复  zhlong8


    嗯。对于两个的情况还行,多个并集可能实现起来有点儿麻烦。谢谢提供思路
junlingpang 发表于 2011-06-09 22:34



    对计算机来说多个和两个没有质的区别,它就是做重复运算的。而且写出来的程序具有通用性,抽象级别很高

论坛徽章:
0
9 [报告]
发表于 2011-06-09 22:41 |只看该作者
回复 8# zhlong8


    嗯,我试一下,谢谢大侠

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
10 [报告]
发表于 2011-06-09 22:52 |只看该作者
回复 9# junlingpang


    这是最简单的递归思路,其实数端点的方法更快
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP