向上709 2021-12-22 08:22 采纳率: 0%
浏览 22

有一个矩阵,我想利用洪水填充法找到输入字母的所占面积

img

#include <iostream>
#include <fstream>
using namespace std;
#define N 5
int wall1 = -1;
int wall2 = N ;
int area = 0;
void floodfill(int x, int y, char oldcolor, char newcolor, char a[N][N], int area);
int main()
{
    int i, j;
    char oldcolor;
    char newcolor = '0';
    ifstream fileIn("picture.txt", ios::in);
    char a[N][N];
    while (!fileIn.eof())
    {
        for (i = 0; i < N; i++)
        {
            for (j = 0; j < N; j++)
            {
                fileIn >> a[i][j];
            }
        }
    }
    cin >> oldcolor;
    for (i = 0; i < N; i++)
    {
        for (j = 0; j < N; j++)
        {
            if (a[i][j] == oldcolor)
            {
                floodfill(i, j, oldcolor, newcolor, a, area);
            }
        }
    }
    cout << area;
}
void floodfill(int x, int y, char oldcolor, char newcolor, char a[N][N], int area)
{

    if (x == wall1 || x == wall2 || y == wall1 || y == wall2)
    {
        return;
    }

    if (a[x][y] != oldcolor)
    {
        return;
    }
    a[x][y] = newcolor;
    floodfill(x + 1, y, oldcolor, newcolor, a, area);
    floodfill(x - 1, y, oldcolor, newcolor, a, area);
    floodfill(x, y + 1, oldcolor, newcolor, a, area);
    floodfill(x, y - 1, oldcolor, newcolor, a, area);
    return;
}

运行后面积始终为零

img

修改了几次都一直是这个结果
最终目的是想得到字母的中心位置和面积
  • 写回答

1条回答 默认 最新

  • 赵4老师 2021-12-22 09:10
    关注

    遍历即可
    没必要用floodfill算法。

    评论

报告相同问题?

问题事件

  • 创建了问题 12月22日

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改