码迷,mamicode.com
首页 > 其他好文 > 详细

基本算法——for循环的使用之魔方阵实现

时间:2014-10-09 14:48:43      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   os   使用   ar   for   

魔方阵,是一种每一行、每一列以及对角线的和相等。

魔方阵的一种特性是:

  1.第一个元素1的位置始终在第一行正中。

  2.下一个元素的位置总是在刚插入位置的右上方。

  3.如果右上方的位置超出方阵上边界,则新的位置应取列的最下位置。

  4.如果右上方的位置超出方阵右边界,则新的位置应取行的最座位置。

  5.若刚插入的元素为n的整数倍,则选刚插入元素位置的下一行同列插入下一元素。

实现代码如下:

bubuko.com,布布扣
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #define M 20
 4 int main(int argc,char *argv[])
 5 {
 6     int num=1,len,row,col;
 7     int a[M][M];
 8     printf("请输入要输出的行数:");
 9     scanf("%d",&len);
10     row=0;
11     col=len/2;
12     a[row][col]=num++;
13     while(num <= len *len)
14     {
15         if(((num-1)%len) == 0)
16         {
17             row=(row+1)%len;
18         }
19         else
20         {
21             row=(row-1+len)%len;
22             col=(col+1)%len;
23         }
24         a[row][col]=num++;
25     }
26     for(row=0;row<len;row++)
27     {
28         for(col=0;col<len;col++)
29             printf("%3d",a[row][col]);
30         printf("\n");
31     }
32     system("pause");
33     return 0;
34 }
View Code

逻辑上设计是:

  1.首先判断上一元素是否为N的倍数。

  2.然后再对下一位置进行取余操作,这样无论是否越界都会得到正确的位置。

基本算法——for循环的使用之魔方阵实现

标签:style   blog   http   color   io   os   使用   ar   for   

原文地址:http://www.cnblogs.com/gjn135120/p/4012357.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!