声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1104|回复: 3

[编程技巧] 计算数组分块数量的问题

[复制链接]
发表于 2009-9-26 19:58 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
请问:例如数组
[1 1 2 2 3 3
1 1 2 3 3 3
2 2 2 1 1 3
2 2 1 1 1 1]
上下左右的数如果与它相同的,则计为同一块,现在要怎么计算这个数组总共有几块?
比如上面举例的数组总共就有4块,左上角的1为一块,2为一块,3为一块,右下角的1为一块。

之前想用递归程序去计算的,但运算速度非常慢,得不出答案。但考虑用递推计算的话,思路还没理清。。。请问各位应该如何实现这种计算?谢谢
回复
分享到:

使用道具 举报

发表于 2009-9-26 21:06 | 显示全部楼层
能否不用递归或递推,直接检测边界并数边界。

评分

1

查看全部评分

 楼主| 发表于 2009-9-26 21:16 | 显示全部楼层
可否具体解释下怎么实现呢?之前有想过检测每个分块的最左边和左右边的位置,之后逐数递推
发表于 2009-9-27 10:33 | 显示全部楼层
试试blkproc
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2025-1-6 19:52 , Processed in 0.062550 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表