免费注册 查看新帖 |

Chinaunix

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

数组组合---合并神马 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-09-08 10:18 |只看该作者 |倒序浏览
本帖最后由 thomaslyang 于 2011-09-09 22:10 编辑

转移阵地, stack overflow 见!!!

论坛徽章:
0
2 [报告]
发表于 2011-09-08 10:28 |只看该作者
这个用一个施瓦茨转换就可以搞定吧?

论坛徽章:
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
3 [报告]
发表于 2011-09-08 10:39 |只看该作者
有没重复的?保持不保持顺序的?只有字符串数字等简单的东西吗?3、6不分你让我好纠结 {:3_188:}

论坛徽章:
0
4 [报告]
发表于 2011-09-08 11:00 |只看该作者
有没重复的?保持不保持顺序的?只有字符串数字等简单的东西吗?3、6不分你让我好纠结
zhlong8 发表于 2011-09-08 10:39

已纠正,不用排序

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
5 [报告]
发表于 2011-09-08 11:24 |只看该作者
已纠正,不用排序
thomaslyang 发表于 2011-09-08 11:00


试试用hash比较简单....

论坛徽章:
0
6 [报告]
发表于 2011-09-08 11:27 |只看该作者
回复 2# x9x9
能具体点吗?那个算法没接触过, 举个例子吧, 麻烦你了

论坛徽章:
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
7 [报告]
发表于 2011-09-08 11:48 |只看该作者
my $ref_arr = [['A',1,2,3,4], ['B', 34,7,98], ['A', 6,7,8], ['C', 56, 1], ['B', 45,7,8], ['D', 69, 890, 11]];

my %map;

for my $ary (@$ref_arr) {
    my($key, @val) = @$ary;
    unless (exists $map{$key}) {
        push @{$map{$key}}, @$ary;
    }
    else {
        push @{$map{$key}}, @val;
    }
}

my @ret;
push @ret, $map{$_} for sort keys %map;

say Dumper \@ret;

论坛徽章:
0
8 [报告]
发表于 2011-09-08 12:16 |只看该作者
use Data::Dumper;
my $x = [['A',1,2,3,4], ['B', 34,7,98], ['A', 6,7,8], ['C', 56, 1], ['B', 45,7,8], ['D', 69, 890, 11]];
push @{$h{shift @$_}},@$_ for @$x;
print Dumper \%h;

论坛徽章:
0
9 [报告]
发表于 2011-09-08 12:42 |只看该作者
兰花仙子 发表于 2011-09-08 12:16


#对仙子的程序的补全
#个人为C程序员,对for 倒置相当不习惯
my $arr = [];
push @$arr, [$_, @{$h{$_}}] for (sort {$a cmp $b} (keys %h));

print Dumper $arr;

论坛徽章:
0
10 [报告]
发表于 2011-09-08 13:36 |只看该作者
回复  x9x9
能具体点吗?那个算法没接触过, 举个例子吧, 麻烦你了
thomaslyang 发表于 2011-09-08 11:27


仙子版主很简单的用push和for循环就搞定了,根本都不用施瓦茨转换,相对来说我想复杂了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP