国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python 連連看連接算法

2019-11-25 18:45:42
字體:
來源:轉載
供稿:網友
功能:為連連看游戲提供連接算法
說明:模塊中包含一個Point類,該類是游戲的基本單元“點”,該類包含屬性:x,y,value。
其中x,y代表了該點的坐標,value代表該點的特征:0代表沒有被填充,1-8代表被填充為游戲圖案,9代表被填充為墻壁
模塊中還包含一個名為points的Point列表,其中保存著整個游戲界面中的每個點
使用模塊的時候應首先調用createPoints方法,初始化游戲界面中每個點,然后可通過points訪問到每個點,繼而初始化界面
模塊中核心的方法是link,通過提供源點和終點,可嘗試連接兩點,如果可以連接則返回保存路徑的path列表,否則返回False

復制代碼 代碼如下:

#-*-coding:utf-8-*-
"""連連看連接算法

為連連看游戲提供連接算法
模塊中包含一個Point類,該類是游戲的基本單元“點”,該類包含屬性:x,y,value。
其中x,y代表了該點的坐標,value代表該點的特征:0代表沒有被填充,1-8代表被填充為游戲圖案,9代表被填充為墻壁
模塊中還包含一個名為points的Point列表,其中保存著整個游戲界面中的每個點
使用模塊的時候應首先調用createPoints方法,初始化游戲界面中每個點,然后可通過points訪問到每個點,繼而初始化界面
模塊中核心的方法是link,通過提供源點和終點,可嘗試連接兩點,如果可以連接則返回保存路徑的path列表,否則返回False
"""
import random

__author__ ="http://blog.csdn.net/anhulife"
__license__ ="python"

class Point:
"""Point類

Point類是游戲中基本單元:“點”
"""
def __init__(self,x,y,value):
self.x = x
self.y = y
self.value = value
self.directs = None
self.changed = 0
def __createDirect(self,pre,target):
"""構造點的方向集

每個點在連接的過程中都持有一個方向集,這個方向集中保存著該點的前進方向選擇的優先級
優先級:指向目標點的方向級別最高,在同等級別并且遵循x方向優先于y方向
"""
self.directs = list()
stx = target.x - self.x
sty = target.y - self.y
if stx >= 0 :
self.directs.append("right")
self.directs.append("left")
else:
self.directs.append("left")
self.directs.append("right")
if sty >= 0 :
self.directs.insert(1,"up")
self.directs.append("down")
else:
self.directs.insert(1,"down")
self.directs.append("up")
if pre == None :
return
spx = pre.x - self.x
spy = pre.y - self.y
if spx == 0 :
if spy == 1:
self.directs.remove("up")
else:
self.directs.remove("down")
else :
if spx == 1:
self.directs.remove("right")
else:
self.directs.remove("left")
def forward(self,pre,target):
"""點的前進動作

點的前進即是依次從方向集中取出優先級高的方向,并判斷該方向上的下一個點是否被填充
如果沒有被填充則說明該方向可通,并返回該方向。否則試探下一個方向,如果方向集中沒有方向可用了,則返回None
"""
if self.directs == None :
self.__createDirect(pre,target)
if len(self.directs) == 0 :
return None
direct = None
while(True):
if len(self.directs) == 0 :
break
tmpDirect = self.directs.pop(0)
if tmpDirect == "up" :
x = self.x
y = self.y + 1
elif tmpDirect == "down":
x = self.x
y = self.y - 1
elif tmpDirect == "left":
x = self.x - 1
y = self.y
elif tmpDirect == "right":
x = self.x + 1
y = self.y
p = points[x][y]
if p.value > 0 and p != target:
continue
else :
direct = tmpDirect
if pre == None:
self.changed = 1
else:
if (pre.x - self.x) == 0 and (p.x - self.x) == 0:
self.changed = 0
else:
if (pre.y - self.y) == 0 and (p.y - self.y) == 0:
self.changed = 0
else :
self.changed = 1
break
return direct
def isChanged(self):
"""判斷方向變化

返回在該點前進時,是否帶來了方向的變化,即方向不同于原方向
"""
return self.changed
def __eq__(self,p):
if p == None :
return False
if self.x == p.x and self.y == p.y :
return True
else:
return False
points = list()
def createPoints(w,h):
"""構造游戲界面的點

初始化界面中的所有的點,并且規則如下:
最外一層是“墻壁”點,接下來的一層是沒有被填充的點,被包裹的是填充的點
"""
r = random.randint
for x in range(w):
temp = list()
for y in range(h):
if x == 0 or x == (w-1) or y == 0 or y == (h-1):
temp.append(Point(x,y,9))
else:
if x == 1 or x == (w-2) or y == 1 or y == (h-2):
temp.append(Point(x,y,0))
else:
temp.append(Point(x,y,r(1,8)))
points.append(temp)
def link(source,target):
"""點的連接

連接方法的思想:針對源點的每個方向嘗試前進,如果可以前進,則將針對該方向上的下個點的每個方向嘗試前進
當一個點的可選方向都不能前進的時候,則返回到已有前進路徑中的前一個點,嘗試該點其他可選方向。當回源點
的每個方向都走不通或是路徑的方向變化等于4的時候,連接失敗返回False。否則當路徑連接到目標點而且路徑的方向變化小
于4的時候,連接成功返回路徑
"""
if source == target:
return False
path = list()
change = 0
current = source
while True:
if current==target and change < 4:
for p in path:
p.directs = None
return path
if change == 4:
current.directs = None
current = path.pop(len(path)-1)
change = change - current.isChanged()
continue
if change == 0:
direct = current.forward(None,target)
else:
direct = current.forward(path[len(path)-1],target)
if direct != None:
change = change + current.isChanged()
if direct == "up" :
x = current.x
y = current.y + 1
elif direct == "down":
x = current.x
y = current.y - 1
elif direct == "left":
x = current.x - 1
y = current.y
elif direct == "right":
x = current.x + 1
y = current.y
print x,y
path.append(current)
current = points[x][y]
else:
if change == 0:
return False
else:
current.directs = None
current = path.pop(len(path)-1)
change = change - current.isChanged()
createPoints(8,8)
p = link(points[2][2],points[5][2])
print p
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 舒城县| 资溪县| 湛江市| 泸水县| 安西县| 前郭尔| 平安县| 四会市| 朝阳市| 博客| 如皋市| 石嘴山市| 哈尔滨市| 开封县| 墨玉县| 翁牛特旗| 舟山市| 阿城市| 松阳县| 商都县| 五峰| 永春县| 依兰县| 高台县| 大埔县| 长海县| 甘谷县| 射阳县| 万山特区| 班玛县| 西峡县| 赞皇县| 武宁县| 崇阳县| 景洪市| 九台市| 台湾省| 重庆市| 大渡口区| 平阳县| 威宁|