模拟2048游戏

这个博客介绍了一个2048游戏的实现,包括左移、右移、上移和下移操作的详细步骤。代码使用Python编写,通过矩阵运算来处理游戏状态,并实现了游戏的移动和合并功能。玩家可以通过键盘输入指令控制游戏进程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

模拟2048游戏

import random
list_merge = None

square_matrix = [
    [0, 0, 0, 0],
    [0, 0, 0, 0],
    [0, 0, 0, 0],
    [0, 0, 0, 0],
]


def zero_to_end():
    """
    将所有元素去0,依次放置,末尾添加0
    :return:
    """
    for i in range(len(list_merge) - 1, -1, -1):
        if list_merge[i] == 0:
            del list_merge[i]
            list_merge.append(0)


def add():
    """
    计算两个相邻相同元素的和
    :return:
    """
    zero_to_end()
    for i in range(1, len(list_merge)):
        if list_merge[i] == list_merge[i - 1]:
            list_merge[i - 1] += list_merge[i]
            del list_merge[i]
            list_merge.append(0)


def left_move():
    """
    左移
    :return:
    """
    for line in square_matrix:
        global list_merge
        list_merge = line
        add()


def right_move():
    """
    右移
    :return:
    """
    for line in square_matrix:
        global list_merge
        list_merge = line[::-1]
        add()
        line[::-1] = list_merge


def up_move():
    """
    上移
    :return:
    """
    square_matrix_transpose(square_matrix)
    left_move()
    square_matrix_transpose(square_matrix)


def down_move():
    """
    下移
    :return:
    """
    square_matrix_transpose(square_matrix)
    right_move()
    square_matrix_transpose(square_matrix)


def square_matrix_transpose(squ_matrix):
    """
    方阵转置
    :param squ_matrix:
    :return:
    """
    for r in range(1, len(squ_matrix)):
        for c in range(r, len(squ_matrix[r])):
            squ_matrix[c][r - 1], squ_matrix[r - 1][c] = \
                squ_matrix[r - 1][c], squ_matrix[c][r - 1]


def play_game():
    """
    执行
    :return:
    """
    create_square_matrix()
    print_square()
    while True:
        execute_square_matrix()
        run = input("请输入要进行的操作:上移[W],下移[S],左移[A],右移[D]:").title()
        print_square()
        if run == "W":
            up_move()
        if run == "S":
            down_move()
        if run == "A":
            left_move()
        if run == "D":
            right_move()


def create_square_matrix():
    """
    首次生成方阵
    :return:
    """
    r_c_index01 = random.randint(0, 3)
    r_c_index02 = random.randint(0, 3)
    r_c_index03 = random.randint(0, 3)
    r_c_index04 = random.randint(0, 3)
    index01 = random.randrange(2, 5, 2)
    index02 = random.randrange(2, 5, 2)

    if r_c_index01 != r_c_index03 or r_c_index02 != r_c_index04:
        square_matrix[r_c_index01][r_c_index02] = index01
        square_matrix[r_c_index03][r_c_index04] = index02
    return square_matrix


def execute_square_matrix():
    """
    方阵随机添加一个元素
    :return:
    """
    r_c_index01 = random.randint(0, 3)
    r_c_index02 = random.randint(0, 3)
    index01 = random.randrange(2, 5, 2)
    if square_matrix[r_c_index01][r_c_index02] == 0:
        square_matrix[r_c_index01][r_c_index02] = index01
    else:
        square_matrix[r_c_index01][r_c_index02] = square_matrix[r_c_index01][r_c_index02]
    return square_matrix


def print_square():
    """
    以矩阵的形式输出
    :return:
    """
    for i in range(0, 4):
        print(square_matrix[i])


play_game()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

键律疯魔

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值