1.顺时针打印矩阵的代码
#include<stdio.h>
void PrintMatrixInCircle(int (*data)[3],int rows,int columns,int start)
{
int endx=columns-start-1;
int endy=rows-start-1;
//从左到右打印一行
for(int i=start;i<=endx;++i)
{
int number=data[start][i];
printf("%d",number);
}
//从上到下打印一列
if(start<endy)
{
for(int i=start+1;i<=endy;++i)
{
int number=data[i][endx];//注意不是data[endx][i]
printf("%d",number);
}
}
//从右向左打印一行,注意打印的起始位置
if(start<endy&&start<endx)
{
for(int i=endx-1;i>=start;--i)
{
int number=data[endy][i];
printf("%d",number);
}
}
//从下到上打印一列,注意起始和结束的位置
if((start<endy-1)&&(start<endx))
{
for(int i=endy-1;i>=start+1;--i)
{
int number=data[i][start];
printf("%d",number);
}
}
}
void PrintMatrixClockwisely(int (*data)[3],int rows,int columns)
{
if(data==NULL||rows<=0||columns<=0)
return;
int start=0;
while((rows>start*2)&&(columns>start*2))//打印循环的起点位置范围是:从矩阵最左边到矩阵中央位置
{
PrintMatrixInCircle(data,rows,columns,start);
++start;
}
}
int main()
{
int num[][3]={{1,2,3},
{4,5,6},
{7,8,9}};
PrintMatrixClockwisely(num,3,3);
getchar();
}
2.以上程序涉及到二维数组作为函数参数的问题
有三种方法将二维数组作为函数参数传递,三种方法中在主函数中都是给出二维数组的首地址,在被调用函数中有三种形参表示方法。
(1)形参给出第二维的长度。
void PrintMatrixInCircle(int data[ ][3],int rows,int columns,int start)
对于二维数组可以省略第一维的长度,但是必须保留第二维的长度,否则系统将无法区分有多少行多少列。
那有人会问,如果指定第一维,而不指定第二维系统也能确定有多少行多少列吧?
比如写成data[3][ ],这里存在一个问题,就是当实参维数大于形参维数时相当于只取实参的一部分数据。
所以二维数组的参数声明可以写成如下两种格式:data[ ][3 ]和data[3][3],但不可以写成data[3][ ]的形式。
(2)形参声明为指向数组的指针。
void PrintMatrixInCircle(int (*data)[3],int rows,int columns,int start)
注意指针加1时,实际地址变化以指针指向的数据类型所占用的地址大小为单位增加。
(3)void PrintMatrixInCircle(int **data,int rows,int columns,int start)
在C++中可以这样声明:
int** numbers = new int*[rows];
for(int i = 0; i < rows; ++i)
{
numbers[i] = new int[columns];//对于二维数组data[3][3],data[0]、data[1]、data[2]可以看作一维数组名
for(int j = 0; j < columns; ++j)
{
numbers[i][j] = i * columns + j + 1;
}
}