首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Flood Fill时遇到循环

使用Flood Fill时遇到循环
EN

Stack Overflow用户
提问于 2012-06-12 09:26:42
回答 1查看 328关注 0票数 0

在运行下面的代码时,我遇到了一个无限循环。在一个被块包围的网格中,一个预定义的方块开始于这个实现运行的方块。如果需要访问一个正方形,则将其标记为1;如果已访问过正方形,则将其标记为2。我似乎找不到解决方案,我希望得到一些有用的提示。

代码语言:javascript
复制
one_count=1;
while(one_count>0){
    for(int i=0;i<24;i++){
        for(int c=0;c<80;c++){
            if(create[i][c]=='1'){
                if(create[i-1][c]==' '){
                    create[i-1][c]='1';
                }
                if(create[i+1][c]==' '){
                    create[i+1][c]='1';
                }
                if(create[i][c-1]==' '){
                    create[i][c-1]='1';
                }
                if(create[i][c+1]==' '){
                    create[i][c+1]='1';
                }
                create[i][c]='2';
            }
        }
    }
    one_count=0;
    for(int i=0;i<24;i++){
        for(int c=0;c<80;c++){
            if(create[i][c]=='1'){
                one_count++;
            }
        }
    }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-06-12 16:33:55

我在随机数据上运行了你的代码(边是'X')。我没有遇到任何循环。

而且,你也没有理由会遇到问题。每一个像素在每次迭代中都会被检查,并且保证所有的‘1’都会变成‘2’。没有退路,也不可能循环。

也许你可以提供更多关于程序行为的信息。

BTW:在您的代码中有一个小问题。洪水向底部和右侧快速填充,因为您已经在周期中编写地图(很难解释->示例)。

循环开始:除了create2=='1'

  • check neighbours

  • etc.

  • create2之外,一切都是‘’,将'1‘写入neighbours,将'2’写入self
  • 检查下一个元素,即create2,它也是'1‘,并填充neighbours
  • etc.

所以在第一个循环之后,你可能只期望create2=='2‘,但是它右边和下面的东西也是=='2’。

它目前不会破坏你的代码,但如果你改变了一些东西,它可能会导致意想不到的结果。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10989509

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档