要求:把40个元素的数组,按每行8个,分5行打印出来。如下图

1 2 3 4 5 6 7 8
9 10 11 12 13 14 15 16
17 18 19 20 21 22 23 24
25 26 27 28 29 30 31 32
33 34 35 36 37 38 39 40

起因:遇到一些处理数据文件的场景,比如每8行求一次平均值,最大值,或者别的什么操作,可以先抽象为每8行打印到一个数组里,然后直接对该数组处理

 #!/usr/bin/perl -w
use strict; my @data = ..; my $window = ; for my $loop(..(@data/$window)-)
{
my @tmp = ();
for my $index (..($window-))
{
push @tmp, $data[$index + $window * $loop];
}
print join("\t", @tmp), "\n";
}

分析:原理很简单,找到索引的规律,就是了,只是每次不能快速的想起来,特此记录一下。关键是用line8, line13, 找到索引的正确公式。

0+8*0, 1+8*0, ... 7+8*0

0+8*1, 1+8*1, ... 7+8*1

...

0+8*4, 1+8*4, ... 7+8*4

推广:  其他语言也可以按这个思路做

 #!/usr/bin/python

 data = range(40)

 window = 8

 for loop in range(len(data)/window):
tmp = []
for index in range(window):
tmp.append(data[index + window * loop])
#print tmp
print "\t".join([str(x) for x in tmp])

不太好的思路:一开始是想到等差数列公式,先求出每行(代表一行数组)的第一个值,后面的根据等差数列公式a1+(n-1)*d,依次求出, 代码有点啰嗦

 #!/usr/bin/perl -w
use strict; my @data = 1..40; my $window = 8;
my $offset = 1; my @tmp = ();
for my $loop(0..(@data/$window - 1))
{
my $first = $data[0] + $loop * $window;
for my $index(1..$window)
{
my $value = $first + ($index - 1) * $offset;
push @tmp, $value;
}
print "@tmp\n";
@tmp = ();
}