邱 璇洛 (ゝ∀・)

邱 璇洛 (ゝ∀・)

你好哇(*゚∀゚*)~这里是邱璇洛的博客,常常用来记录一些技术文章和小日常~(σ゚∀゚)σ
twitter
tg_channel

使用C语言还原一个简单的磁芯大战

起因#

大约半月前,DBinary 大佬举办了一场用代码决胜负的程序员比赛,也就是磁芯大战

虽然菜的抠脚,但咱还是想做个自己的玩玩。

编写#

磁芯大战的逻辑很简单

让用户自己编辑机器人代码 -> 让代码跑起来 -> 游戏结束,看谁圈的地多或者谁把谁干掉了。

因为技术力贫瘠,就先吧圈地先做好💦

首先实现做简单的,渲染一张地图:

//定义地图大小
int map_data[12][12];
/* 加载地图数据 */
void base() {
    for (int i = 0; i < 12; i++) {
        for (int j = 0; j < 12; j++) {
            map_data[j][i] = 0;
        }
    }
}
/* 渲染地图 */
void lod_map() {
    printf("\n");
    for (int i = 0; i < 12; i++) {
        for (int j = 0; j < 12; j++) {
            printf("[%d]", map_data[i][j]);
        }
        printf("\n");
    }
    printf("\n");
}

然后,加入并渲染两个玩家:

int p1_data = 1;
int p2_data = 2;

/* 当前坐标 */
int p1_now[] = {0,0};
int p2_now[] = {11,11};
...

/* 渲染玩家 */
void lod_map() {
    map_data[p1_now[0]][p1_now[1]] = p1_data;
    map_data[p2_now[0]][p2_now[1]] = p2_data;
...

}

写一个玩家控制器和加载玩家代码:

/* Mobile control */
void move(int direction, int player) {
    if (player==1) {
        switch (direction) {
            /* down */
            case 1:
                p1_now[0] = p1_now[0]+1;
                break;
            /* up */
            case 2:
                p1_now[0] = p1_now[0]-1;
                break;
            /* left */
            case 3:
                p1_now[0] = p1_now[1]-1;
                break;
            /* right */
            case 4:
                p1_now[0] = p1_now[1]+1;
                break;
            default:
                break;
        }
    } else {
        switch (direction) {
            /* down */
            case 1:
                p2_now[0] = p2_now[0]+1;
                break;
            /* up */
            case 2:
                p2_now[0] = p2_now[0]-1;
                break;
            /* left */
            case 3:
                p2_now[0] = p2_now[1]-1;
                break;
            /* right */
            case 4:
                p2_now[0] = p2_now[1]+1;
                break;
            default:
                break;
        }
    }
}

/* Control the player */
void player_1() {
    move(1, 1);
    move(1, 1);
}

void player_2() {
    move(2, 2);
}

/* Read the player data */
void lod_player() {
    player_1();
    player_2();
}

统计程序

/* Statistical game data */
void lod_end() {
    int p1_num;
    int p2_num;
    for (int i = 0; i < 12; i++) {
        for (int j = 0; j < 12; j++) {
            if (map_data[i][j] == 1) {
                p1_num++;
            } else if (map_data[i][j] == 2) {
                p2_num++;
            }
        }
    }
    /* printf("[INFO]Game data: P1:%d, P2:%d\n", p1_num-12, p2_num-12); */
    if (p1_num<p2_num) {
        printf("[WIN]P2 win!\n");
    } else if (p1_num>p2_num) {
        printf("[WIN]P1 win!\n");
    } else {
        printf("[WIN]No Winner.");
    }
    
}

最后,启动游戏!

int main() {
    printf("\n[INFO] Start Game\n\n");
    base();
    for (int i=0; i<12; i++) {
        printf("[INFO] Round %d", i);
        lod_player();
        lod_map();
        sleep(1);
        
        /* Some mod(?) */
        //printf("\33[2J \033[0m");
        //printf("\007 \033[0m\n");
    }

    lod_end();

    return 0;
}

完整代码: Github

好多鱼.png

加载中...
此文章数据所有权由区块链加密技术和智能合约保障仅归创作者所有。