免费注册 查看新帖 |

Chinaunix

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

大神求帮忙,求出合作网络矩阵 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-11-13 15:00 |只看该作者 |倒序浏览
本帖最后由 w123456_cu 于 2015-11-13 22:04 编辑

---------------合作关系列表--------------
       科技项目     合作省份
        项目1        湖北                        
        项目2        四川                        
        项目3        北京        上海        四川        
        项目4        四川        广州               
        项目5        广州        湖北               
        项目6        四川        广州        上海        湖北
        项目7        上海        广州               
        项目8        北京        四川        广州        湖北
        项目9        广州                        
        项目10               
        项目11        


希望求合作矩阵(其中,数值表示合作频次)       

                               

        湖北        四川        北京        广州        上海
湖北        0        2        1        3        1
四川        2        0        2        3        2
北京        1        2        0        1        1
广州        3        3        1        0        2
上海        1        2        1        2        0

论坛徽章:
0
2 [报告]
发表于 2015-11-13 23:03 |只看该作者
本帖最后由 w123456_cu 于 2015-11-13 23:23 编辑
  1. use v6;

  2.     my %hash;

  3.   for 'data_cooperation.txt'.IO.lines {
  4.        my ($, @item) = .words;
  5.        my @copy = @item;

  6.                for @item ->$a {   #二重循环遍历每个单词
  7.                        for @copy -> $b {
  8.                              %hash{$a}{$b}++;
  9.                               }
  10.                        }
  11. }

  12.         my  @uu = %hash.keys.sort;
  13.                 ##   
  14.                print "item \t";      
  15.                say join("\t", @uu);   #输出首行
  16.                ##

  17.           for @uu -> $i {
  18.                  print "$i\t";     #输出首列
  19.                  for @uu -> $j {
  20.                       if defined(%hash{$i}{$j}) {  #对角元为0
  21.                              print ($i eqv $j) ?? "0\t" !! "%hash{$i}{$j}\t" ;   
  22.                                 }
  23.                          }
  24.                  print "\n";  
  25.                }
复制代码

论坛徽章:
0
3 [报告]
发表于 2015-11-13 23:07 |只看该作者
本帖最后由 w123456_cu 于 2015-11-13 23:24 编辑

感觉没有perl6的美感,
请大神指点

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
4 [报告]
发表于 2015-11-13 23:28 |只看该作者
本帖最后由 sunzhiguolu 于 2015-11-13 23:33 编辑

Perl 6 - 只能像您学习了...

论坛徽章:
0
5 [报告]
发表于 2015-11-14 11:15 |只看该作者
回复 1# w123456_cu
  1. #!perl6

  2. my ( %item, @item );

  3. for 'data'.IO.lines {
  4.     ( *, @item ) = .words;
  5.     for @item X @item {
  6.         %item{.[0]}{.[1]} += [ne] $_;
  7.     }
  8. }

  9. say join "\t", 'item', @item = %item.keys;
  10. say join "\t", .key, .value{@item} «||» 0 for %item;


复制代码

论坛徽章:
0
6 [报告]
发表于 2015-11-14 11:48 |只看该作者
@ba_du_co  精炼

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
7 [报告]
发表于 2015-11-14 14:41 |只看该作者
Perl 6 的语法怎么这么诡异呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP