zoukankan      html  css  js  c++  java
  • 基本算法——for循环的使用之魔方阵实现

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

    魔方阵的一种特性是:

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

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

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

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

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

    实现代码如下:

     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("
    ");
    31     }
    32     system("pause");
    33     return 0;
    34 }
    View Code

    逻辑上设计是:

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

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

  • 相关阅读:
    input输入框的各种样式
    Spring JdbcTemplate方法详解
    TF/IDF计算方法
    分布式日志收集系统--Chukwa
    分布式日志系统
    Iframe知识点
    拖拽事件
    面向对象知识点
    JS使用合并数组
    块元素block,内联元素inline; inline-block;
  • 原文地址:https://www.cnblogs.com/gjn135120/p/4012357.html
Copyright © 2011-2022 走看看