ホームページ > バックエンド開発 > Python チュートリアル > Snake を実装するための 50 行のコード (具体的なアイデアとコード)

Snake を実装するための 50 行のコード (具体的なアイデアとコード)

WBOY
リリース: 2016-06-16 08:46:34
オリジナル
1751 人が閲覧しました

私は最近、インタビュー用にいくつかの小さなデモを準備していました。その 1 つは、私自身のプログラミングの実践を説明するために、自分で設計して実装したものです。方法 -- 言語の詳細を理解するために、コードを短く記述します。

コードをコピー コードは次のとおりです:

import sys, pygame
pygame.locals から import *
ランダムインポート randrange から
up =lambda x:(x[0]-1,x[1])
down = lambda x :(x [0] +1,x[1])
左 = ラムダ x : (x[0],x[1]-1)
右 = ラムダ x : (x[0],x[1] +1)
tl = lambda x :xtr = lambda x :x==0 and 3 or x-1
dire = [up,left,down, right]
move = ラムダ x,y:[y(x[0])]+x[:-1]
grow = ラムダ x,y:[y(x[0])]+x
s = [(5,5),(5,6),(5,7)]
d = 上
食べ物 = randrange(0,30),randrange(0,40)
FPSCLOCK=pygame .time.Clock()
pygame.init()
pygame.display.set_mode((800,600))
pygame.mouse.set_visible(0)
screen = pygame.display. get_surface()
screen.fill((0,0,0))
times=0.0
while True:
time_passed = FPSCLOCK.tick(30)
if 回>=150:
回 =0.0
s = move(s,d)
else:
times +=time_passed
for イベント in pygame.event.get():
ifevent.type == QUIT :
sys.exit()
ifevent.type == KEYDOWN およびevent.key == K_UP:
s = move(s,d)
if events.type == KEYDOWN およびevent .key == K_LEFT:
d=dire[tl(dire.index(d))]
ifevent.type == KEYDOWN およびevent.key == K_RIGHT:
d=dire [tr( dire.index(d))]
if s[0]==food:
s = give(s,d)
food =randrange(0,30),randrange(0, 40)
if s[0] in s[1:] or s[0][0]= 30 or s[0][1]break
screen.fill((0,0,0))
for r,c in s:
pygame.draw.rect (screen, (255,0,0),(c*20,r*20,20,20))
pygame.draw.rect(screen,(0,255,0),(food[1]*20, food[0 ]*20,20,20))
pygame.display.update()


ゲームのスクリーンショット:
Snake を実装するための 50 行のコード (具体的なアイデアとコード)
説明:
1. 実際には、pygame は必要ありませんが、いくつかの条件判定を変更すると、半分に短縮できると推定されます。 。 Python のスキルが上がったら、もう一度戻って試してみてください。 。
2. ただし、Snake コードは 50 行でも読むことができます。あまり短く書くと無理です。 。
3. 重要なのは、ラムダ式と関数オブジェクトを使用して回転、移動などのアルゴリズムを実装することです。 。
4. どの「ウォーカー」がより短く書けるか、喜んで教えます....
著者: aiqier
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート