Python新手实现2048小游戏


Posted in Python onMarch 31, 2015

接触 Python 不久,看到很多人写2048,自己也捣鼓了一个,主要是熟悉Python语法。

程序使用Python3 写的,代码150行左右,基于控制台,方向键使用输入字符模拟。

演示图片

Python新手实现2048小游戏

2048.py

# -*- coding:UTF-8 -*-
#! /usr/bin/python3
 
import random
 
v = [[0, 0, 0, 0],
   [0, 0, 0, 0],
   [0, 0, 0, 0],
   [0, 0, 0, 0]]
 
def display(v, score):
    '''显示界面
 
    '''
    print('{0:4} {1:4} {2:4} {3:4}'.format(v[0][0], v[0][1], v[0][2], v[0][3]))
    print('{0:4} {1:4} {2:4} {3:4}'.format(v[1][0], v[1][1], v[1][2], v[1][3]))
    print('{0:4} {1:4} {2:4} {3:4}'.format(v[2][0], v[2][1], v[2][2], v[2][3]))
    print('{0:4} {1:4} {2:4} {3:4}'.format(v[3][0], v[3][1], v[3][2], v[3][3]), '  Total score: ', score)
 
def init(v):
    '''随机分布网格值
     
    '''
    for i in range(4):
        v[i] = [random.choice([0, 0, 0, 2, 2, 4]) for x in range(4)]
 
def align(vList, direction):
    '''对齐非零的数字
 
    direction == 'left':向左对齐,例如[8,0,0,2]左对齐后[8,2,0,0]
    direction == 'right':向右对齐,例如[8,0,0,2]右对齐后[0,0,8,2]
    '''
 
    # 移除列表中的0
    for i in range(vList.count(0)):
        vList.remove(0)
    # 被移除的0
    zeros = [0 for x in range(4 - len(vList))]
    # 在非0数字的一侧补充0
    if direction == 'left':
        vList.extend(zeros)
    else:
        vList[:0] = zeros
     
def addSame(vList, direction):
    '''在列表查找相同且相邻的数字相加, 找到符合条件的返回True,否则返回False,同时还返回增加的分数
     
    direction == 'left':从右向左查找,找到相同且相邻的两个数字,左侧数字翻倍,右侧数字置0
    direction == 'right':从左向右查找,找到相同且相邻的两个数字,右侧数字翻倍,左侧数字置0
    '''
    score = 0
    if direction == 'left':
        for i in [0, 1, 2]:
            if vList[i] == vList[i+1] != 0: 
                vList[i] *= 2
                vList[i+1] = 0
                score += vList[i]
                return {'bool':True, 'score':score}
    else:
        for i in [3, 2, 1]:
            if vList[i] == vList[i-1] != 0:
                vList[i-1] *= 2
                vList[i] = 0
                score += vList[i-1]
                return {'bool':True, 'score':score}
    return {'bool':False, 'score':score}
 
def handle(vList, direction):
    '''处理一行(列)中的数据,得到最终的该行(列)的数字状态值, 返回得分
 
    vList: 列表结构,存储了一行(列)中的数据
    direction: 移动方向,向上和向左都使用方向'left',向右和向下都使用'right'
    '''
    totalScore = 0
    align(vList, direction)
    result = addSame(vList, direction)
    while result['bool'] == True:
        totalScore += result['score']
        align(vList, direction)
        result = addSame(vList, direction)
    return totalScore
     
 
def operation(v):
    '''根据移动方向重新计算矩阵状态值,并记录得分
    '''
    totalScore = 0
    gameOver = False
    direction = 'left'
    op = input('operator:')
    if op in ['a', 'A']:  # 向左移动
        direction = 'left'
        for row in range(4):
            totalScore += handle(v[row], direction)
    elif op in ['d', 'D']: # 向右移动
        direction = 'right'
        for row in range(4):
            totalScore += handle(v[row], direction)
    elif op in ['w', 'W']: # 向上移动
        direction = 'left'
        for col in range(4):
            # 将矩阵中一列复制到一个列表中然后处理
            vList = [v[row][col] for row in range(4)]
            totalScore += handle(vList, direction)
            # 从处理后的列表中的数字覆盖原来矩阵中的值
            for row in range(4):
                v[row][col] = vList[row]
    elif op in ['s', 'S']: # 向下移动
        direction = 'right'
        for col in range(4):
            # 同上
            vList = [v[row][col] for row in range(4)]
            totalScore += handle(vList, direction)
            for row in range(4):
                v[row][col] = vList[row]
    else:
        print('Invalid input, please enter a charactor in [W, S, A, D] or the lower')
        return {'gameOver':gameOver, 'score':totalScore}
 
    # 统计空白区域数目 N
    N = 0
    for q in v:
      N += q.count(0)
    # 不存在剩余的空白区域时,游戏结束
    if N == 0:
        gameOver = True
        return {'gameOver':gameOver, 'score':totalScore}
 
    # 按2和4出现的几率为3/1来产生随机数2和4
    num = random.choice([2, 2, 2, 4]) 
    # 产生随机数k,上一步产生的2或4将被填到第k个空白区域
    k = random.randrange(1, N+1)
    n = 0
    for i in range(4):
        for j in range(4):
            if v[i][j] == 0:
                n += 1
                if n == k:
                    v[i][j] = num
                    break
 
    return {'gameOver':gameOver, 'score':totalScore}
 
init(v)
score = 0
print('Input:W(Up) S(Down) A(Left) D(Right), press <CR>.')
while True:
    display(v, score)
    result = operation(v)
    if result['gameOver'] == True:
        print('Game Over, You failed!')
        print('Your total score:', score)
    else:
        score += result['score']
        if score >= 2048:
            print('Game Over, You Win!!!')
            print('Your total score:', score)

以上所述就是本文给大家分享的全部代码了,希望能够对大家学习Python有所帮助。

Python 相关文章推荐
让python的Cookie.py模块支持冒号做key的方法
Dec 28 Python
python3使用PyMysql连接mysql数据库实例
Feb 07 Python
python使用 HTMLTestRunner.py生成测试报告
Oct 20 Python
python 3.0 模拟用户登录功能并实现三次错误锁定
Nov 01 Python
python获取酷狗音乐top500的下载地址 MP3格式
Apr 17 Python
django连接mysql配置方法总结(推荐)
Aug 18 Python
Python多进程池 multiprocessing Pool用法示例
Sep 07 Python
基于python实现KNN分类算法
Apr 23 Python
Python实现的远程文件自动打包并下载功能示例
Jul 12 Python
Python中一个for循环循环多个变量的示例
Jul 16 Python
python rsync服务器之间文件夹同步脚本
Aug 29 Python
python不相等的两个字符串的 if 条件判断为True详解
Mar 12 Python
举例介绍Python中的25个隐藏特性
Mar 30 #Python
在Python的循环体中使用else语句的方法
Mar 30 #Python
python实现2048小游戏
Mar 30 #Python
利用一个简单的例子窥探CPython内核的运行机制
Mar 30 #Python
30分钟搭建Python的Flask框架并在上面编写第一个应用
Mar 30 #Python
编写同时兼容Python2.x与Python3.x版本的代码的几个示例
Mar 30 #Python
以Python的Pyspider为例剖析搜索引擎的网络爬虫实现方法
Mar 30 #Python
You might like
PHP 文件上传源码分析(RFC1867)
2009/10/30 PHP
php编程实现获取excel文档内容的代码实例
2011/06/28 PHP
Codeigniter操作数据库表的优化写法总结
2014/06/12 PHP
php格式化时间戳显示友好的时间实现思路及代码
2014/10/23 PHP
javascript 有用的脚本函数
2009/05/07 Javascript
jquery select(列表)的操作(取值/赋值)
2009/08/06 Javascript
javascript事件问题
2009/09/05 Javascript
Jquery遍历checkbox获取选中项value值的方法
2014/02/13 Javascript
使用RequireJS优化JavaScript引用代码的方法
2015/07/01 Javascript
利用JS实现数字增长
2016/07/28 Javascript
Vue2.0学习之详解Vue 组件及父子组件通信
2017/12/12 Javascript
vue中路由验证和相应拦截的使用详解
2017/12/13 Javascript
node作为中间服务层如何发送请求(发送请求的实现方法详解)
2018/01/02 Javascript
VUE简单的定时器实时刷新的实现方法
2019/01/20 Javascript
小程序从手动埋点到自动埋点的实现方法
2019/01/24 Javascript
jsonp实现百度下拉框功能的方法分析
2019/05/10 Javascript
layui树形菜单动态遍历的例子
2019/09/23 Javascript
js实现鼠标拖拽div左右滑动
2020/01/15 Javascript
JS倒计时两种实现方式代码实例
2020/07/27 Javascript
jQuery实现评论模块
2020/08/19 jQuery
[46:28]EG vs Liquid 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.23
2019/09/05 DOTA
Python命令行参数解析模块getopt使用实例
2015/04/13 Python
python用模块zlib压缩与解压字符串和文件的方法
2016/12/16 Python
Python设计模式之代理模式简单示例
2018/01/09 Python
DataFrame:通过SparkSql将scala类转为DataFrame的方法
2019/01/29 Python
Python 获取numpy.array索引值的实例
2019/12/06 Python
Python 3.8 新功能来一波(大部分人都不知道)
2020/03/11 Python
keras-siamese用自己的数据集实现详解
2020/06/10 Python
日本一家专门经营各种箱包的大型网站:Traveler Store
2016/08/03 全球购物
印尼在线精品店:Berrybenka.com
2016/10/22 全球购物
爱尔兰灯和灯具网上商店:Lights.ie
2018/03/26 全球购物
电子商务求职信
2014/06/15 职场文书
教师师德师风个人整改方案
2014/09/18 职场文书
党员三严三实对照检查材料
2014/10/13 职场文书
党的群众路线教育实践活动整改落实情况自查报告
2014/10/28 职场文书
如何撰写创业策划书
2019/06/27 职场文书