24小时热门版块排行榜    

查看: 759  |  回复: 4
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

philip890220

铜虫 (初入文坛)

[求助] 求助各位高手,关于perl程序~~

我现在遇到一个程序,想了几天也没想出来,有点棘手的说,所以向高手求助~~,我所要处理的文件格式正如图片所示(当然实际处理的文件不论行数还是列数都要比图片中的大好多),第一步需要计算出每个null在所在行和所在列的个数的百分比,就拿左上角第一个null来说,所在行总共有4个null,所在行总数为6个,所以百分比为66.7%,还是左上角第一个null,所在列只有一个null,所以百分比是33.3%,第二步需要比较上面算出的两个百分比个数,取较小的那个,左上角null所在行的百分比是66.7%,所在列的百分比是33.3%,我们取33.3%,然后算出该列所有数值的平均值,并将这个null值替换为该平均值,最后将所有的null值换算成数值并输出到一个txt格式的文件。
程序有点难的说~~
图一



图二,注意左上角null已经变成0.097846876和0.097714819的平均值
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : file.txt
  • 2012-09-11 10:55:17, 229 bytes

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

philip890220

铜虫 (初入文坛)

引用回帖:
4楼: Originally posted by wizardfan at 2012-09-12 19:56:58
I do not understand why you use push(@array,);
In my traditional way, two dimensional hash will be more useful $hash{$rowIndex}{$columnIndex}
e.g. in your example, $hash{0}{0} = null, $hash{1}{0}  ...

ok,I have a try!thanks~~
5楼2012-09-12 20:16:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 5 个回答

wizardfan

至尊木虫 (著名写手)

优秀版主

【答案】应助回帖

感谢参与,应助指数 +1
说说你自己的想法,我来帮你把关。
2楼2012-09-12 05:05:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

philip890220

铜虫 (初入文坛)

jjdg: 编辑内容 2012-09-12 10:32
jjdg: 编辑内容 2012-09-12 10:32
引用回帖:
2楼: Originally posted by wizardfan at 2012-09-12 05:05:24
说说你自己的想法,我来帮你把关。

怎么说呢,这个程序我真的是一脸茫然,前两天试了 一下,算出了每行没列中null的个数并且存到了数组里,但是我不知道怎么样将每行和每列对应起来,反正挺晕的~~
open(MA,"test.txt" )||die "error $!";
open(OUT,">test_1.txt" );

while( ){
@row = split;
push(@array,[@row]);
}

$num_null_row=0;
$num_null_col=0;
for($i=0;$i   for($x=0;$x    if($array[$i][$x]=~/null/){
    $num_null_row++;
    }   
  }
  push(@num_null_row,$num_null_row);
  $num_null_row=0;
}

for($i=0;$i   for($x=0;$x     if($array[$x][$i]=~/null/){
    $num_null_col++;
    }
  }
  push(@num_null_col,$num_null_col);
  $num_null_col=0;
}

[ Last edited by jjdg on 2012-9-12 at 10:32 ]
3楼2012-09-12 08:38:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wizardfan

至尊木虫 (著名写手)

优秀版主

【答案】应助回帖

引用回帖:
3楼: Originally posted by philip890220 at 2012-09-12 08:38:29
怎么说呢,这个程序我真的是一脸茫然,前两天试了 一下,算出了每行没列中null的个数并且存到了数组里,但是我不知道怎么样将每行和每列对应起来,反正挺晕的~~
open(MA,"test.txt" )||die " ...

I do not understand why you use push(@array,[@row]);
In my traditional way, two dimensional hash will be more useful $hash{$rowIndex}{$columnIndex}
e.g. in your example, $hash{0}{0} = null, $hash{1}{0} = 0.097846876
4楼2012-09-12 19:56:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见