C语言课程设计
层叠方阵起始数放在方阵的左上角,然后从起始数开始先在同行后在同列递增,层层折叠地排列为层叠方阵。如下图为起始数是1,行数是5的层叠方阵。使用数组方法设计程序,打印输出起始...
层叠方阵
起始数放在方阵的左上角,然后从起始数开始先在同行后在同列递增,层层折叠地排列为层叠方阵。如下图为起始数是1,行数是5的层叠方阵。
使用数组方法设计程序,打印输出起始数为a,行数为m(a,m从键盘输入确定)的层叠方阵。
1 2 5 10 17
4 3 6 11 18
9 8 7 12 19
16 15 14 13 20
25 24 23 22 21
【编程提示】
设置变量n从a开始,依次增1。然后根据层叠方阵的特点给二维数组z[x][y]赋值。第i层(i=2,3,…,m)的起始位置为(1,i),随后列号y不变行号x递增,至x==i时转折,行号x不变列号y递减,至y==1时该层结束,每一位置递增的n赋值给z[x] [y]。
上机测试成功给分
邮箱:362903700@qq.com 展开
起始数放在方阵的左上角,然后从起始数开始先在同行后在同列递增,层层折叠地排列为层叠方阵。如下图为起始数是1,行数是5的层叠方阵。
使用数组方法设计程序,打印输出起始数为a,行数为m(a,m从键盘输入确定)的层叠方阵。
1 2 5 10 17
4 3 6 11 18
9 8 7 12 19
16 15 14 13 20
25 24 23 22 21
【编程提示】
设置变量n从a开始,依次增1。然后根据层叠方阵的特点给二维数组z[x][y]赋值。第i层(i=2,3,…,m)的起始位置为(1,i),随后列号y不变行号x递增,至x==i时转折,行号x不变列号y递减,至y==1时该层结束,每一位置递增的n赋值给z[x] [y]。
上机测试成功给分
邮箱:362903700@qq.com 展开
展开全部
这个就行
#include<stdio.h>
int main()
{
int a[100][100];
int num=1;//起始数字
int i,j;
int n=0;//矩阵行列数
printf("起始数字num=");
scanf("%d",&num);
printf("请输入行列数n=");
scanf("%d",&n);
for(i=0; i<n; i++)
{
int p;
a[i][i]=num+i*(i+1);
p=a[i][i];
for(j=i-1; j>=0; j--)//行排列
{
p+=1;
a[i][j]=p;
}
p=a[i][i];
for(j=i-1; j>=0; j--)//列排列
{
p-=1;
a[j][i]=p;
}
}
for(i=0; i<n; i++)
{
for(j=0; j<n; j++)
{
printf("%5d ",a[i][j]);
}
printf("\n");
}
}
#include<stdio.h>
int main()
{
int a[100][100];
int num=1;//起始数字
int i,j;
int n=0;//矩阵行列数
printf("起始数字num=");
scanf("%d",&num);
printf("请输入行列数n=");
scanf("%d",&n);
for(i=0; i<n; i++)
{
int p;
a[i][i]=num+i*(i+1);
p=a[i][i];
for(j=i-1; j>=0; j--)//行排列
{
p+=1;
a[i][j]=p;
}
p=a[i][i];
for(j=i-1; j>=0; j--)//列排列
{
p-=1;
a[j][i]=p;
}
}
for(i=0; i<n; i++)
{
for(j=0; j<n; j++)
{
printf("%5d ",a[i][j]);
}
printf("\n");
}
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询