粥之语 2022-10-27 09:00 采纳率: 50%
浏览 26
已结题

扫雷问题中总是有不正确的输出


#include<stdio.h>
int main()
{
    char a[100][100];
    int n, i, j;
    scanf("%d", &n);
    getchar();
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            scanf("%c", &a[i][j]);
        }
    }
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            if (a[i][j] == '*')
            {
                if(j==n-1)
                {
                    printf("*\n");
                }
                else if (j != n - 1)
                {
                    printf("*");
                }
            }
            else if (a[i][j] == 'o')
            {
                if (i > 0 && i < n - 1 && j>0 && j < n - 1)
                {
                    int count = 0;
                    for (int m = i - 1; m <= i + 1; m++)
                    {
                        for (int y = j - 1; y <= j + 1; y++)
                        {
                            if (a[m][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                    printf("%d", count );
                }
                else if (i == 0 && j == 0)
                {
                    int count = 0;
                    for (int m = 0; m <= 1; m++)
                    {
                        for (int y = 0; y <= 1; y++)
                        {
                            if (a[m][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                    printf("%d", count );
                }
                else if (i == n - 1 && j == n - 1)
                {
                    int count = 0;
                    for (int m = n - 2; m <= n - 1; m++)
                    {
                        for (int y = n - 2; y <= n - 1; y++)
                        {
                            if (a[m][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                    printf("%d\n", count );
                }
                else if (i == 0 && j == n - 1)
                {
                    int count = 0;
                    for (int m = 0; m <= 1; m++)
                    {
                        for (int y = n - 2; y <= n - 1; y++)
                        {
                            if (a[m][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                    printf("%d\n", count );
                }
                else if (i == n - 1 && j == 0)
                {
                    int count = 0;
                    for (int m = n - 2; m <= n - 1; m++)
                    {
                        for (int y = 0; y <= 1; y++)
                        {
                            if (a[m][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                    printf("%d", count );
                }
                else if (i == 0 && j >= 1 && j <= n - 2)
                {
                    int count = 0;
                    for (int m = 0; m <=  1; m++)
                    {
                        for (int y = j-1; y <= j+1; y++)
                        {
                            if (a[m][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                    printf("%d", count );
                }
                else if (i == n-1 && j >= 1 && j <= n - 2)
                {
                    int count = 0;
                    for (int m = n-2; m <= n-1; m++)
                    {
                        for (int y = j - 1; y <= j + 1; y++)
                        {
                            if (a[m][y] == '*')
                            {
                                count++;
                            }
                        }
                    }
                    printf("%d", count );
                }
                else if (j == 0 && i >= 1 && i <= n - 2)
                {
                int count = 0;
                for (int m = i-1; m <= i+1; m++)
                {
                    for (int y = 0; y <=1; y++)
                    {
                        if (a[m][y] == '*')
                        {
                            count++;
                        }
                    }
                }
                printf("%d", count );
                }
                else if (j == n-1 && i >= 1 && i <= n - 2)
                {
                int count = 0;
                for (int m = i - 1; m <= i + 1; m++)
                {
                    for (int y = n-2; y <= n-1; y++)
                    {
                        if (a[m][y] == '*')
                        {
                            count++;
                        }
                    }
                }
                printf("%d\n", count );
                }
            }
        }
    }
    
    return 0;
}
标准答案输出是第一张照片,我的输出是第二张照片,看不懂也不明白错在哪里

![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/140523238666167.jpg "#left")
  • 写回答

3条回答 默认 最新

  • CSDN专家-link 2022-10-27 09:11
    关注

    for (i = 0; i < n; i++)
    {
    for (j = 0; j < n; j++)
    {
    scanf("%c", &a[i][j]);
    }
    }
    你所有输入字符都在同一行吗?如果分成多行,那么每行的结束符你必须加getchar()接收才行。
    改为:

    for (i = 0; i < n; i++)
    {
            for (j = 0; j < n; j++)
                 scanf("%c", &a[i][j]);
            getchar();
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 11月27日
  • 已采纳回答 11月19日
  • 创建了问题 10月27日

悬赏问题

  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法