一个矩阵怎么c语言程序设计,C语言编程如何实现输出一个回型递增的N阶矩阵(螺旋矩阵)...

该博客介绍了一种用C++实现回型矩阵填充的算法,通过多维数组来存储数据。首先,定义矩阵大小并初始化数组,然后采用四个方向的for循环填充元素,确保不重复填充已赋值的元素。对于奇数阶矩阵,特别处理中心元素。最后,程序输出填充后的矩阵。整个过程涉及数组操作、条件判断及循环控制。
摘要由CSDN通过智能技术生成

首先,说到输出矩阵无论什么水平的人都会认为使用数组最为方便,所以这里说明的是利用多维数组的实现。

首先是算法需要的变量定义

int i,j,n,sum;

printf("请输入矩阵的行列长度:\n");

scanf("%d",&n);

int juzhen[n][n];

memset(juzhen,0,sizeof(juzhen));

sum=1;

其次就是核心算法,此程序核心在于如何写入元素到定义的数组中,要实现回型的数据递增,就必须使用不同的方法的输入不同方向递增的数据;

还有这里要注意数组的定义,是从0号下标开始填入元素(当然从下标为一的元素开始也是可以的,此方法类似不予说明);

另外在换方向输入的时候还要注意前一方向已经输入数据的数组元素不能再输入,于是使用if语句以区分是否填充过数据(这里需要提前将数组全部置零,使用了memset函数,此函数需要头文件string.h)。

这里定义了for语句实现的四种方向的输入

for(i=0;i

{

for(j=0;j

{

if(juzhen[i][j]==0)

juzhen[i][j]=sum++;

}

for(j=i;j

{

if(juzhen[j][n-1-i]==0)

juzhen[j][n-1-i]=sum++;

}

for(j=n-i-1;j>i;j--)//向左

{

if(juzhen[n-1-i][j]==0)

juzhen[n-1-i][j]=sum++;

}

for(j=n-1-i;j>i;j--)//向上

{

if(juzhen[j][i]==0)

juzhen[j][i]=sum++;

}

最后在对输入的数字做区分,当N阶矩阵是一个偶数阶的矩阵时没有矩阵中心元素,但是奇数阶矩阵有,语句如下

if(n%2==1)

juzhen[(n-1)/2][(n-1)/2]=sum++;

最后对数组进行输出

for(i=0;i<=n-1;i++)

for(j=0;j<=n-1;j++)

{

printf("%4d",juzhen[i][j]);

if(j==n-1)

printf("\n");

}

完整源代码如下

```

#include

#include

int main()

{

int i,j,n,sum;

printf("请输入矩阵的行列长度:\n");

scanf("%d",&n);

int juzhen[n][n];

memset(juzhen,0,sizeof(juzhen));

sum=1;

for(i=0;i

{

for(j=0;j

{

if(juzhen[i][j]==0)

juzhen[i][j]=sum++;

}

for(j=i;j

{

if(juzhen[j][n-1-i]==0)

juzhen[j][n-1-i]=sum++;

}

for(j=n-i-1;j>i;j--)//向左

{

if(juzhen[n-1-i][j]==0)

juzhen[n-1-i][j]=sum++;

}

for(j=n-1-i;j>i;j--)//向上

{

if(juzhen[j][i]==0)

juzhen[j][i]=sum++;

}

}

if(n%2==1)

juzhen[(n-1)/2][(n-1)/2]=sum++;

for(i=0;i<=n-1;i++)

for(j=0;j<=n-1;j++)

{

printf("%4d",juzhen[i][j]);

if(j==n-1)

printf("\n");

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值