定义整型二维数组 aiMyarray : array of array of integer 大小设置 setlength(aiMyarray,5,5)
三、多维数组的定义 当一维数组元素的类型也是一维数组时,便构成了二维数组。二维数组定义的一般格式: array[下标类型1] of array[下标类型2] of 元素类型; 但我们一般这样定义二维数组: array[下标类型1,下标类型2] of 元素类型; 说明:其中两个下标类型与一维数组定义一样,可以看成“下界1..上界1”和“下界2..上界2”, 给出二维数组中每个元素( 双下标变量)可以使用下标值的范围。of后面的元素类型就是基类型。 一般地,n维数组的格式为: array[下标类型1,下标类型2,…,下标类型n] of 元素类型; 其中,下标类型的个数即数组的维数,且说明了每个下标的类型及取值范围。
引用内容a[i,j]=i*j。 for i:=1 to 5 do for j:=1 to 4 do a[i,j]:=i*j;
对二维数组的输入与输出也同样可用二重循环来实现:
引用内容for i:=1 to 5 do begin for j:=1 to 4 do read(a[i,j]); end; for i:=1 to 5 do begin for j:=1 to 4 do write(a[i,j]:5); end;
eg、多维数组的应用示例
例7、设有一程序:
引用内容program ex5_3; const n=3; type matrix=array[1..n,1..n]of integer; var a:matrix; i,j:1..n; begin for i:=1 to n do begin for j:=1 to n do read(a[i,j]); readln; end; for i:=1 to n do begin for j:=1 to n do write(a[j,i]:5); writeln; end; end.
引用内容program ex5_4; var a:array[1..4,1..7]of real; i,j:integer; begin fillchar(a,sizeof(a),0); {函数fillchar用以将a中所有元素置为0} writeln(’Enter 4 students score’); for i:=1 to 4 do begin for j:=1 to 5 do {读入每个人5科成绩} begin read(a[i,j]); {读每科成绩时同时统计总分} a[i,6]:=a[i,6]+a[i,j]; end; readln; a[i,7]:=a[i,6]/5;{求平均分} end; writeln( ’No. Mat. Phy. Eng. Che. Pas. Tot. Ave.’); {输出成绩表} for i:=1 to 4 do begin write(i:2,’ ’); for j:=1 to 7 do write(a[i,j]:9:2); writeln; {换行} end; end.
1 in div 2+1,yn /*排数的初始位置*/ 2 a[i,j]1; 3 for k:=2 to n*n do 4 计算下一个排数位置!(i,j); 5 if a[i,j]<>0 then 6 ii-1; 7 jj-2; 6 a[i,j]k; 7 endfor
对于计算下一个排数位置,按上述的四种情形进行,但我们应先处理第三处情况。算法描述如下:
1 if (i=n)and(j=n) then 2 jj-1; /*下一个位置为(n,n-1)*/; 3 else 4 ii mod n +1; 5 jj mod n +1; 6 endif;
源程序如下:
引用内容program ex5_7; var a :array[1..99,1..99]of integer; i,j,k,n :integer; begin fillchar(a,sizeof(a),0); write(‘n=’);readln(n); i:=n div 2+1;j:=n; a[i,j]:=1; for k:=2 to n*n do begin if (i=n)and(j=n) then j:=j-1 else begin i:=i mod n +1; j:=j mod n +1; end; if a[i,j]<>0 then begin i:=i-1; j:=j-2; end; a[i,j]:=k; end; for i:=1 to n do begin for j:=1 to n do write(a[i,j]:5); writeln; end; end.