库里斯托 2023-02-21 11:09 采纳率: 88.5%
浏览 14
已结题

关于#扫雷游戏#的问题,如何解决?

img

img

img

#include<stdio.h>
void initBoard(char arr[102][102], int N, int M)
{
    for (int i = 0; i < 102; i++)
    {
        for (int j = 0; j < 102; j++)
        {
            arr[i][j] = '^';
        }
    }
    for (int i = 1; i <= N; i++)
    {
        for (int j = 1; j <= M; j++)
        {
            scanf("%c", &arr[i][j]);
        }
        getchar();
    }
}
int get_mine_count(char mine[102][102], int x, int y)
{
    return (mine[x - 1][y] +
        mine[x + 1][y] +
        mine[x][y - 1] +
        mine[x][y + 1] +
        mine[x - 1][y - 1] +
        mine[x - 1][y + 1] +
        mine[x + 1][y - 1] +
        mine[x + 1][y + 1] - 8 * '^')/('*'-'^');
}
void findMine(char arr[102][102], int N, int M)
{
    for (int i = 1; i <= N; i++)
    {
        for (int j = 1; j <= M; j++)
        {
            if (arr[i][j] == '*')
            {
                printf("%c",arr[i][j]);
            }
            else
            {
                printf("%c",'0'+get_mine_count(arr, i, j));
            }
        }
        printf("\n");
    }
}
int main()
{
    int count = 1;
    int N = 0;
    int M = 0;
    char arr[102][102] = { 0 };
    while(scanf("%d %d\n", &N, &M)!=EOF)
    {
//         getchar();
        if (M == N && N == 0)
        {
            return 0;
        }
        initBoard(arr, N, M);
        printf("Field #%d:\n",count);
        findMine(arr, N, M);
        printf("\n");
        count++;
     }
    
    return 0;
}

第11行循环为什么不从0开始呢

  • 写回答

2条回答 默认 最新

  • 快乐鹦鹉 2023-02-21 11:18
    关注

    思路是这样的,i=0,j=0就是边上一圈,代码将雷区不放到矩阵的边界上,是代码写起来更容易一些,不需要对边界位置进行特殊处理。
    因为一旦放到边界,那么get_mine_count函数中你就必须进行特殊处理,判断x和y值是否为0,否则x-1就出问题了。不放在边界,就不需要考虑这个问题,代码逻辑就简单很多。同样,雷区矩阵也不包括数组的右边界

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月11日
  • 已采纳回答 3月3日
  • 创建了问题 2月21日

悬赏问题

  • ¥15 Stata链式中介效应代码修改
  • ¥15 latex投稿显示click download
  • ¥15 请问读取环境变量文件失败是什么原因?
  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错