N×N矩阵螺旋打印输出

例:
1 2 3
4 5 6
7 8 9
输出为如下结果
1;4;7;8;9;6;3;2;5;


    private void button1_Click(object sender, EventArgs e)
    {
        //测试例子初始化,并将数组显示到控制台
        int[,] intArray = new int[5, 8];
        int intPos = 0;
        Console.WriteLine();
        for (int i = 0; i < 5; i++)
        {
            for (int j = 0; j < 8; j++)
            {
                intPos++;
                intArray[i, j] = intPos;

                Console.Write(intPos.ToString().PadRight(4));
            }
            Console.WriteLine();
        }

        Console.WriteLine();

        this.PrintArray(1, intArray);
    }


    private void PrintArray(int intPos, int[,] array)
    {
        int intRow = array.GetLength(0);
        int intCell = array.GetLength(1);

        //只要任何没有输出的内容,就无需继续
        bool blnFlag = false;
        //左边
        for (int i = intPos - 1; i <= intRow - intPos; i++)
        {
            blnFlag = true;
            Console.Write(array[i, intPos - 1].ToString() + " ");
        }

        if (blnFlag)
        {
            blnFlag = false;
            //下边
            for (int i = intPos; i <= intCell - intPos; i++)
            {
                blnFlag = true;
                Console.Write(array[intRow - intPos, i].ToString() + " ");
            }
        }

        if (blnFlag)
        {
            //右边
            blnFlag = false;
            for (int i = intRow - intPos - 1; i >= intPos - 1; i--)
            {
                Console.Write(array[i, intCell - intPos].ToString() + " ");
                blnFlag = true;
            }
        }

        if (blnFlag)
        {
            //上边
            blnFlag = false;
            for (int i = intCell - intPos - 1; i >= intPos; i--)
            {
                Console.Write(array[intPos - 1, i].ToString() + " ");
                blnFlag = true;
            }
        }

        if (!blnFlag)
        {
            return;
        }
        else
        {
            this.PrintArray(intPos + 1, array);
        }

    }

转载于:https://www.cnblogs.com/kelebing/archive/2009/08/11/1543447.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值