Description
在C语言中,多维数组是按行存储的。一个m行n列的二维数组相当于一个mn个元素的数组。
那么,一个数组中存储了q(=mn)个元素,可以输出成一个二维数组。
Input
输入首先是一个整数T(0<T<=50),随后有T组测试数据,占两行。
第一行首先是一整数q(0<q<=1000),随后有q个小于100的整数,且都不是负数。
第二行是2个整数m、n,满足q=m*n且m,n>0。
Output
每组测试数据输出为一个m行n列二维数组。二维数组的每个元素占用两个字符输出,每行的两个元素间用一个空格分开。两组测试数据之间用一个空行分隔,但最后一组数据之后不要多添加空行(矩阵结尾的换行符仍保留)。
输出详细格式见sample。
Sample Input
2
12 11 10 9 8 7 6 5 4 3 2 1 0
3 4
10 1 2 3 4 5 6 7 8 9 10
1 10
Sample Output
11 10 9 8
7 6 5 4
3 2 1 0
1 2 3 4 5 6 7 8 9 10
#include<stdio.h>
int main()
{
int T,q,m,n,j,k,l=0,i;
scanf("%d",&T);
for(i=1;i<=T;i++)
{
scanf("%d",&q);
int a[q];
for(j=0;j<q;j++)
{
scanf("%d",&a[j]);
}
scanf("%d%d",&m,&n);
int b[m][n];
for(j=0;j<m;j++)
{
for(k=0;k<n;k++)
{
b[j][k]=a[l];
l++;
}
}
for(j=0;j<m;j++)
{
for(k=0;k<n;k++)
{
if(k==0)
printf("%2d",b[j][k]);
else
printf(" %2d",b[j][k]);
}
printf("\n");
}
l=0;
printf("\n");
}
}
对于刚学习二维数组的小伙伴,这道题当做练习还是挺不错的哦~~