PTA 二维数组与字符数组 7-3 构建n阶幻方阵

20 篇文章 2 订阅

7-3 构建n阶幻方阵

幻方阵又称魔方阵,是将1~n×n的整数放置在1个n×n的方阵中(n的值为奇数),且保证每行、每列及主对角线、副对角线上的数值之和相等。

本题要求实现n-幻方阵(阶数最大为15),n的值从键盘读入。 N为奇数时,N幻方构造算法为:

(1) 将1放在第一行中间一列;

(2)从2开始直到n×n为止各数依次按下列规则存放:按右上方向行走,即每一个数存放的行比前一个数的行数减1,列数加1。

(3) 如果行列范围超出矩阵范围,则回绕。

(4) 如果按上面规则确定的位置上已有数,则将其放在上一个数的下面。

输入格式:

输入一个正奇数n。

输出格式:

按照样例的格式输出n级幻方阵,每列占4个字符,右对齐。

输入样例:

5

结尾无空行

输出样例:

  17  24   1   8  15
  23   5   7  14  16
   4   6  13  20  22
  10  12  19  21   3
  11  18  25   2   9

示例解答:

#include<stdio.h>
int main(){
	int n,i,sta,k,chu,kkk=1;
	scanf("%d",&n);
	int a[n][n];
	sta=(n-1)/2;
	chu=0;
	for(i=0,k=0;i<n*n;i++){
		a[chu][sta]=kkk;
		kkk++;k++;
		if(k==n){
			chu=chu+1;
			k=0;
			continue;//结束此次循环进入下一次
		}//此时下一个数输到当前数字的下方

		if(chu==0){
			chu=n-1;
		}//第一行转到最后一行
		else chu--;
		if(sta==n-1){
			sta=0;
		}//最后一列提到最前
		else sta++;
		}
	for(i=0;i<n;i++){
		for(k=0;k<n;k++){
			printf("%4d",a[i][k]);
		}
		printf("\n");
	}
	return 0;
}

  • 12
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值