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. 输出

相关推荐
小成202303202654 小时前
Linux高级02
linux·开发语言
钢琴上的汽车软件5 小时前
C 语言中const与指针:三种常见写法辨析
c语言·指针和const
知行合一。。。5 小时前
Python--04--数据容器(总结)
开发语言·python
咸鱼2.05 小时前
【java入门到放弃】需要背诵
java·开发语言
ZK_H5 小时前
嵌入式c语言——关键字其6
c语言·开发语言·计算机网络·面试·职场和发展
A.A呐5 小时前
【C++第二十九章】IO流
开发语言·c++
椰猫子5 小时前
Java:异常(exception)
java·开发语言
lifewange5 小时前
pytest-类中测试方法、多文件批量执行
开发语言·python·pytest
ambition202425 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
cmpxr_6 小时前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法