以下のような同じサイズの配列がいくつかあります。
@m1= (1,1,0,1);
@m2= (0,1,1,1);
@m3= (0,1,1,0);
@m4= (1,1,0,0);
問題は、このような 1 つの配列にどのように配置できるかです。
@m = (
[1,1,0,1],
[0,1,1,1],
[0,1,1,0],
[1,1,0,0]
);
編集:配列をコピーしたいので(コメントに従って)、私はこれを行います--
my @m = ( [ @m1 ], [ @m2 ], [ @m3 ], [ @m4 ] );
詳細については、 perldoc perlrefおよびperldoc perlreftutを参照してください。
元の答え:
それらを 1 つの配列にフラット化する場合:
my @m = ( @m1, @m2, @m3, @m4 );
配列参照の配列が必要な場合:
my @m = ( \@m1, \@m2, \@m3, \@m4 );
例:
use Data::Dumper;
my @m1= (1,1,0,1);
my @m2= (0,1,1,1);
my @m3= (0,1,1,0);
my @m4= (1,1,0,0);
my @m = ( @m1, @m2, @m3, @m4 );
warn Dumper( \@m );
my @m_again = ( \@m1, \@m2, \@m3, \@m4 );
warn Dumper( \@m_again );
出力:
$VAR1 = [
1,
1,
0,
1,
0,
1,
1,
1,
0,
1,
1,
0,
1,
1,
0,
0
];
$VAR1 = [
[
1,
1,
0,
1
],
[
0,
1,
1,
1
],
[
0,
1,
1,
0
],
[
1,
1,
0,
0
]
];
my @m = ( \@m1, \@m2, \@m3, \@m4 );
but you should probably have avoided putting them into separate arrays to begin with.
For example,
my @m1 = (1,1,0,1);
my @m2 = (0,1,1,1);
...
my @m = ( \@m1, \@m2, \@m3, \@m4 );
can be written as
my @m = (
[1,1,0,1],
[0,1,1,1],
...
);
For example,
my @m1 = f();
my @m2 = g();
...
my @m = ( \@m1, \@m2, \@m3, \@m4 );
can be written as
my @m;
$m[0] = [ f() ];
$m[1] = [ g() ];
...
or
my @m;
push @m, [ f() ];
push @m, [ g() ];
...