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.然后再对下一位置进行取余操作,这样无论是否越界都会得到正确的位置。

  • 相关阅读:
    .net core之上传文件的限制
    如何Telnet端口
    ES坑之logstash配置文件
    MySQL报错packets larger than max_allowed_packet are not allowed
    ES坑之安装
    ES坑之概述
    Git
    IDEA 搭建 maven(下)
    IDEA搭建maven(上)
    JDBC
  • 原文地址:https://www.cnblogs.com/gjn135120/p/4012357.html
Copyright © 2011-2022 走看看