免费注册 查看新帖 |

Chinaunix

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

用perl完成练习题:Minimum Scalar Product [复制链接]

论坛徽章:
1
申猴
日期:2014-04-18 16:29:14
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-03-30 14:07 |只看该作者 |倒序浏览
本帖最后由 Mr-Summer 于 2013-03-30 14:14 编辑

https://code.google.com/codejam/contest/32016/dashboard#s=p0
Google Code Jam 上的练习题目(计算给定2个数组的两两乘积和的最小值),想用Perl试一下但是不知道结果为啥不对,求解惑。
  1. open IN,"D:/Home/Perl/Google Code Jam/A-small-practice.in";
  2. open OUT, ">","D:/Home/Perl/Google Code Jam/A-small-practice.out";
  3. $test_case_num = <IN>;
  4. $n = 0;
  5. for(1..$test_case_num){
  6.         $result = 0;
  7.         $m = 0;
  8.         $n ++;
  9.         $row = <IN>;
  10.         $line_1 =<IN>;
  11.         $line_2 = <IN>;
  12.         @arr_1 = split(/ / , $line_1);
  13.         @arr_2 = split(/ / , $line_2);
  14.         @arr_1 = sort @arr_1;
  15.         @arr_2 = sort @arr_2;
  16.         @arr_2 = reverse @arr_2;
  17.         for( 1..$row){
  18.                 $result = $result + $arr_1[$m]*$arr_2[$m];
  19.                 $m++;
  20.         }
  21.     printf OUT ("Case #%d: %d\n",$n,$result);
  22. }
  23. close IN;
  24. close OUT;
复制代码

论坛徽章:
0
2 [报告]
发表于 2013-03-30 15:21 |只看该作者
初看有如下几个地方的问题:
1. 从文件中读取行后未chomp掉行尾的回车
2. split 中第一个参数直接使用空格, 如果用 /\s+/ 的通用性应该更好
3. printf 函数使用错误,要么所有参数都放到 ()中,要门完全不要括号。

论坛徽章:
0
3 [报告]
发表于 2013-03-30 15:36 |只看该作者
回复 1# Mr-Summer


    首先可以确定的是你的sort用错了,对数字排序是这样:
  1. sort { $a <=> $b} @array;
复制代码

论坛徽章:
1
申猴
日期:2014-04-18 16:29:14
4 [报告]
发表于 2013-03-30 15:50 |只看该作者
kk861123 发表于 2013-03-30 15:36
回复 1# Mr-Summer

谢谢,确实是sort使用错误了。
  1. @arr_1 = sort { $a <=> $b} @arr_1;
  2.         @arr_2 = sort { $b <=> $a} @arr_2;
  3. 这样答案就对了
复制代码

论坛徽章:
1
申猴
日期:2014-04-18 16:29:14
5 [报告]
发表于 2013-03-30 15:53 |只看该作者
回复 3# kk861123
因为写perl只是拿来验证思路,最后还是要改成熟悉的C或者JAVA的,所以写的时候会很不规范,1,2我以后会注意一下的,3我就看不懂了


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP