C语言实例之8输出中国象棋棋盘

1. 题目

输出中国象棋棋盘。

2.分析

首先需要知道中国象棋棋盘布局。

cpp 复制代码
|-------------------|
| 車馬象士将士象馬車 |
|   炮         炮   |
| 卒  卒  卒  卒  卒 |
|-------------------|
|-------------------|
| 兵  兵  兵  兵  兵 |
|   炮         炮   |
| 車馬象士帥士象馬車 |
|-------------------|

根据上述布局依次输出。

3. 实例代码

cpp 复制代码
#include <stdio.h>
#include <windows.h>

int main() {
    // 防止中文乱码
    SetConsoleOutputCP(CP_UTF8);

    const char* arr[8];
    // 使用动态内存分配来初始化每个元素指向的字符串内容
    arr[0] = (const char*)malloc(sizeof(char) * 24);
    strcpy((char*)arr[0], " 車馬象士将士象馬車 ");

    arr[1] = (const char*)malloc(sizeof(char) * 24);
    strcpy((char*)arr[1], "   炮          炮   ");

    arr[2] = (const char*)malloc(sizeof(char) * 36);
    strcpy((char*)arr[2], " 卒  卒  卒  卒  卒 ");

    arr[3] = (const char*)malloc(sizeof(char) * 36);
    strcpy((char*)arr[3], "-------------------");

    arr[4] = (const char*)malloc(sizeof(char) * 36);
    strcpy((char*)arr[4], "-------------------");

    arr[5] = (const char*)malloc(sizeof(char) * 36);
    strcpy((char*)arr[5], " 兵  兵  兵  兵  兵 ");

    arr[6] = (const char*)malloc(sizeof(char) * 36);
    strcpy((char*)arr[6], "   炮          炮   ");

    arr[7] = (const char*)malloc(sizeof(char) * 36);
    strcpy((char*)arr[7], " 車馬象士帥士象馬車 ");

    int nRow = 0;
    printf("中国象棋棋盘:\n");
    while(nRow < 8) {
        printf(arr[nRow]);
        nRow++;
        // 每一行后换行
        printf("\n");
    }

    // 释放动态分配的内存
    for (int i = 0; i < 8; i++) {
        if (arr[i] && ((char*)arr[i])!= NULL) {
            free((void*)arr[i]);
        }
    }
    return 0;
}

4. 输出

相关推荐
炸膛坦客33 分钟前
单片机/C/C++八股:(十九)栈和堆的区别?
c语言·开发语言·c++
零雲34 分钟前
java面试:了解抽象类与接口么?讲一讲它们的区别
java·开发语言·面试
Jay_Franklin1 小时前
Quarto与Python集成使用
开发语言·python·markdown
2401_831824961 小时前
代码性能剖析工具
开发语言·c++·算法
是wzoi的一名用户啊~2 小时前
【C++小游戏】2048
开发语言·c++
weixin_426689202 小时前
vscode C语言编译环境搭建(单个文件)
c语言·ide·vscode
Sunshine for you2 小时前
C++中的职责链模式实战
开发语言·c++·算法
@我漫长的孤独流浪2 小时前
Python编程核心知识点速览
开发语言·数据库·python
qq_416018723 小时前
C++中的状态模式
开发语言·c++·算法
2401_884563243 小时前
模板代码生成工具
开发语言·c++·算法