【c++】 我的世界

太久没更新小游戏了

给个赞和收藏吧,求求了

要游戏的请私聊我

cpp 复制代码
#include <iostream>
#include <vector>

// 定义世界大小
const int WORLD_WIDTH = 20;
const int WORLD_HEIGHT = 10;

// 定义方块类型
enum BlockType {
    AIR,
    GRASS,
    DIRT,
    STONE
};

// 定义世界
std::vector<std::vector<BlockType>> world(WORLD_HEIGHT, std::vector<BlockType>(WORLD_WIDTH, AIR));

// 生成地形
void generateTerrain() {
    for (int x = 0; x < WORLD_WIDTH; ++x) {
        int groundLevel = WORLD_HEIGHT / 2;
        world[groundLevel][x] = GRASS;
        for (int y = groundLevel + 1; y < WORLD_HEIGHT; ++y) {
            if (y < groundLevel + 3) {
                world[y][x] = DIRT;
            } else {
                world[y][x] = STONE;
            }
        }
    }
}

// 打印世界
void printWorld(int playerX, int playerY) {
    for (int y = 0; y < WORLD_HEIGHT; ++y) {
        for (int x = 0; x < WORLD_WIDTH; ++x) {
            if (x == playerX && y == playerY) {
                std::cout << 'P';
            } else {
                switch (world[y][x]) {
                    case AIR:
                        std::cout << ' ';
                        break;
                    case GRASS:
                        std::cout << 'G';
                        break;
                    case DIRT:
                        std::cout << 'D';
                        break;
                    case STONE:
                        std::cout << 'S';
                        break;
                }
            }
        }
        std::cout << std::endl;
    }
}

int main() {
    generateTerrain();

    int playerX = WORLD_WIDTH / 2;
    int playerY = WORLD_HEIGHT / 2 - 1;

    while (true) {
        system("cls"); // 清屏,在 Linux 系统中使用 system("clear");
        printWorld(playerX, playerY);

        std::cout << "使用 w(上), s(下), a(左), d(右) 移动,q 退出: ";
        char input;
        std::cin >> input;

        if (input == 'q') {
            break;
        }

        int newX = playerX;
        int newY = playerY;

        switch (input) {
            case 'w':
                newY--;
                break;
            case 's':
                newY++;
                break;
            case 'a':
                newX--;
                break;
            case 'd':
                newX++;
                break;
        }

        // 检查新位置是否合法
        if (newX >= 0 && newX < WORLD_WIDTH && newY >= 0 && newY < WORLD_HEIGHT) {
            playerX = newX;
            playerY = newY;
        }
    }

    return 0;
}    
相关推荐
啊董dong21 分钟前
课后作业-2025年12月07号作业
数据结构·c++·算法·深度优先·noi
兵哥工控25 分钟前
MFC PostMessage实现进度条实时更新实例
c++·mfc
李日灐33 分钟前
C++STL:list(双链表)的底层实现 && 部分源码解析
开发语言·c++
咕咕嘎嘎10241 小时前
C/C++内存对齐
java·c语言·c++
qq_479875431 小时前
C++ 模板元编程
java·开发语言·c++
爱装代码的小瓶子1 小时前
【cpp知识铺子】map与set的底层AVL树
开发语言·数据结构·c++·b树·算法·链表
修炼地2 小时前
代码随想录算法训练营第二十八天 | 动态规划理论基础、509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
c++·算法·动态规划
吗~喽2 小时前
【C++】模板进阶
c语言·开发语言·c++
我不会插花弄玉2 小时前
类与对象-下【由浅入深-C++】
c++
Tandy12356_2 小时前
手写TCP/IP协议栈——ARP超时重新请求
c语言·c++·网络协议·计算机网络