控制奇数数行的样式只能用n吗_奇数n阶幻方是指由自然数1、2、…、n2组成的n×n的方阵,其中每个元素值都不相等,且每行、每列与对角线上的n个元素之和都相等。 N阶幻方的构造方法有很多种,下面是“右...

1.

(2019高二下·嘉兴期末)

奇数n阶幻方是指由自然数1、2、…、n2组成的n×n的方阵,其中每个元素值都不相等,且每行、每列与对角线上的n个元素之和都相等。

N阶幻方的构造方法有很多种,下面是“右上方填数法”的算法:

⑴将1放在第一行中间一列;

⑵2~n2依次填在上一个数的右上方位置(即行减1列加1):

若上一个数的行数为1时,则当前数的行数为n;

若上一个数的列数为n时,则当前数的列数为1。

⑶如果按上面规则确定的位置上已有数,则把当前数放在上一个数的下面。

例如当n为3时,如图a所示,1在第1行第2列,则2的位置为第3行第3列;

再如3在第2行第1列,则4的位置应为第1行第2列,但该位置已有数,因此4就放在3所在位置的正下面。

“左上方填数法”的方法类似于“右上方填数法”,以3阶幻方为例,“右上方填数法”和“左上方填数法”所构造的幻方如下图a、图b所示。

3ae5dbf6c5a7a41f17c2710b4f17ac1a.png4c6869f3a56cca989ec57ccc5a78e687.png

图a 右上方填数法 图b 左上方填数法

小明采用“左上方填数法”的方法设计了如下程序。

Private Sub Command1_Click()

Dim a(1 To 100) As Integer

Dimx As Integer,y As Integer,x1 As Integer,y1 As Integer

Dim n As Integer, s As Integer,pos As Integer, st As String

n = Val(Text1.Text)

For i = 1 To n * n

a(i) = 0

Next i

s = 1

x = 1

y = (n + 1) \ 2

a(y) = s

Do While ①

s = s + 1

x1 = x: y1 = y

x = x - 1

y = y - 1

If x < 1 Then x = n

If y < 1 Then y = n

If a((x - 1) * n + y) > 0 Then  ②: y = y1

a(pos) = s

Loop

st = ""

For i = 1 To n * n

st = st + wid(a(i))

If i Mod n = 0 Then

List1.AddItem st

st = ""

End If

Next i

End Sub

'自定义函数wid的功能是使数字在方阵对齐

Function wid(p As Integer) As String

'代码省略

End Function

请回答下列问题:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值