粥之语 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 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型