相信大家都做過九宮格的游戲,規則是要求填數字1-9在九個方格內,使橫豎斜相加和相等。只填九個那可能有些簡單,但是填25個,填49個,81個等奇數個那,這時候就要求我們去找其中的規律。找到規律又要如何用代碼實現?
希望大家看代碼之前,先來看下這個口訣:
首居上行正中央,依次斜向右上方,上出框時往下寫,右出框時左邊放,排重退回下格填,右上排重一個樣。
釋義:1要放在第一行的正中央,每次按依次向上的格式去填值,如果超出上邊框就把它豎直往下移到最后一行,如果超出右邊框就把它橫著移動到最左邊,在移動過程中如果要移動的地方已經存在值,就把這個放到前一個數字的下面,如果上邊框和右邊框都超過啦,就和排重一樣,也把這個放到前一個數字的下面。過程如下圖所示
代碼如下:
#!/usr/bin/env python3
#-*- coding:utf-8 -*-
num = int(input('請輸入一個奇數:'))
# 定義一個長為num的列表
high = [[0] * num ]
# 先定義一個num*num的一個列表,之后在往里面賦值
for i in range(num-1):
high += [[0]*num]
n = 1
# 先確定第一行中間值為1
high[0][num//2] = n
x = 0
y = num//2
# 依次向high列表賦值從2開始
for j in range(1,num*num):
# x表示第幾行,y表示第幾列,j表示x,y坐標的值
j = j + 1
x = x - 1
y = y + 1
# 判斷符合哪幾種可能性
if y > (num - 1) and x < 0 :
x = x + 2
y = y - 1
high[x][y]=j
elif x < 0 :
x = num - 1
high[x][y]=j
elif y > num-1 :
y = 0
high[x][y]=j
else:
if high[x][y] == 0 :
high[x][y]=j
elif high[x][y] != 0 :
x = x + 2
y = y - 1
high[x][y]=j
# 依次把high列表中值打印出來
for a in range(num):
for b in range(num):
# rjust表示輸出01,02,03等這種格式,可看我上篇博文介紹
print( str(high[a][b]).rjust(2,'0'),end=' ')
print()
思路:
主要還是理解最上面的那段口訣,口訣理解啦,代碼也就懂啦
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

