zoukankan      html  css  js  c++  java
  • 算法基础系列之三:螺旋形矩阵

    如何打印出如下这样的螺旋形的矩阵:

    1         2  3

    8   9  4

    7   6  5

     

    方法一:

    static void SpiralMatrix(int count)

    {

        int[,] iarray = new int[count, count];

        for (int i = 0; i < count; i++)

        {

            for (int j = 0; j < count; j++)

            {

                iarray[i, j] = 0;

            }

        }

     

        iarray[0, 0] = 1;

        int row = 0;

        int col = 0;

        int temprowsub = 0;

        int tempcolsub = 1;

     

        for (int i = 0; i < count * count; i++)

        {

            if (tempcolsub == 1)//right

            {

                if (col + 1 <= count - 1 && iarray[row, col + 1]==0)//right

                {

                    iarray[row, col + 1] = iarray[row, col] + 1;

                    col++;

                }

                else if (row + 1 <= count - 1 && iarray[row + 1, col] == 0)//down

                {

                    iarray[row + 1, col] = iarray[row, col] + 1;

                    temprowsub = 1;

                    tempcolsub = 0;

                    row++;

                }

                else

                {

                    break;

                }

            }

            else if (tempcolsub == -1)//left

            {

                if (col - 1 >= 0 && iarray[row, col - 1] == 0)//left

                {

                    iarray[row, col - 1] = iarray[row, col] + 1;

                    col--;

                }

                else if (row - 1 >= 0 && iarray[row - 1, col] == 0)//up

                {

                    iarray[row - 1, col] = iarray[row, col] + 1;

                    temprowsub = -1;

                    tempcolsub = 0;

                    row--;

                }

                else

                {

                    break;

                }

            }

            if (temprowsub == -1)//up

            {

                if (row-1 >=0 && iarray[row-1, col] == 0)//up

                {

                    iarray[row-1, col] = iarray[row, col] + 1;

                    row--;

                }

                else if (col + 1 <= count - 1 && iarray[row, col + 1] == 0)//right

                {

                    iarray[row, col + 1] = iarray[row, col] + 1;

                    temprowsub = 0;

                    tempcolsub = 1;

                    col++;

                }

                else

                {

                    break;

                }

            }

            if (temprowsub == 1)//down

            {

                if (row + 1 <= count - 1 && iarray[row+1, col] == 0)//down

                {

                    iarray[row+1, col] = iarray[row, col] + 1;

                    row++;

                }

                else if (col - 1 >= 0 && iarray[row, col - 1] == 0)//left

                {

                    iarray[row, col - 1] = iarray[row, col] + 1;

                    temprowsub = 0;

                    tempcolsub = -1;

                    col--;

                }

                else

                {

                    break;

                }

            }

        }

     

    //TO DO:OUTPUT

    ……

    }

     

    方法二:

    static void SpiralMatrix(int count)

    {

        int round = count - 1;

        int[,] matrix = new int[count, count];

        int num = 1;

     

        for (int r = 0; r < round && num <= count * count; r++)

        {

            for (int tj = r; tj <= round - r; tj++)//top

                matrix[r, tj] = num++;

            for (int ri = r + 1; ri <= round - r; ri++) //right

                matrix[ri, round - r] = num++;

            for (int bj = round - r - 1; bj >= r; bj--)//bottom

                matrix[round - r, bj] = num++;

            for (int li = round - r - 1; li > r; li--)//left

                matrix[li, r] = num++;

        }

    //TO DO:OUTPUT

    ……

    }

     

    方法一是菜鸟我写的,有点类似爬迷宫,代码有点烦。后来在CSDN看到一个比较简洁的(方法二),也抄上来。

  • 相关阅读:
    SQVI和SAP查询QUERY的区别和使用注意事项
    hdu 4119 Isabella's Message
    HaProxy+Keepalived+Mycat高可用群集配置
    Android之RecyclerView简单使用(三)
    2.CCGridAction(3D效果),3D反转特效,凸透镜特效,液体特效,3D翻页特效,水波纹特效,3D晃动的特效,扭曲旋转特效,波动特效,3D波动特效
    怎样cp文件夹时忽略指定的文件夹和文件
    使用boost::property_tree生成带attribute的xml
    数据结构:中序线索二叉树
    像音乐播放App一样移动背景
    【EasyUi】页面设计必学之Layout
  • 原文地址:https://www.cnblogs.com/morvenhuang/p/506057.html
Copyright © 2011-2022 走看看