c语言不用递归实现螺旋数组,c#递归实现螺旋数组

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

namespace ConsoleApplication5

{

class Program

{

public static int[,] a = new int[7, 7];

public static int count = 0;

public static int row = 0;

public static int col = 0;

public static int RowMax = 6;

public static int RowMin = 0;

public static int ColMax = 6;

public static int ColMin = 0;

public static int shangzuo1 = 0;

public static bool c = false;

public static int p = 0;

public static int q = 0;

static void Main(string[] args)

{

digui();

int n = 7;

if(n%2!=0)

a[n / 2, n/ 2] = n*n;

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

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

{

Console.Write(a[i, j] + "\t");

if (j == 6)

Console.WriteLine();

}

Console.ReadLine();

}

public static void digui()

{

while (p == 0 && q == 0)

{

count++;

if (count > 49)

return;

if (c==true)

{

col++;

row++;

ColMin++;

ColMax--;

RowMin++;

RowMax--;

c = false;

}

if (col > ColMax)

{

q = 1;

col--;

count--;

if(count<49)

digui();

}

else

{

a[row, col] = count;

if (count == 49)

return;

col++;

}

}

while (p == 0 && q == 1)

{

count++;

if (count > 49)

return;

row++;

if (row > RowMax)

{

p = 1;

row--;

count--;

if (count < 49)

digui();

}

else

{

a[row, col] = count;

if (count == 49)

return;

}

}

while (p == 1 && q == 1)

{

count++;

if (count >49)

return;

col--;

if (col < ColMin)

{

q = 0;

col++;

count--;

if (count <49)

digui();

}

else

{

a[row, col] = count; if (count == 49)

return;

}

}

while (p == 1 && q == 0)

{

count++;

if (count >49)

return;

row--;

if (row < RowMin)

{

p = 0;

c = true;

row++;

count-=2;

if (count <49)

digui();

}

else

{

if(row>RowMin)

a[row, col] = count; if (count == 49)

return;

}

}

}

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值