查看单个帖子
旧 2019-11-28, 17:20   #1
poster
高级会员
 
注册日期: 2019-11-21
帖子: 3,006
声望力: 66
poster 正向着好的方向发展
默认 计算连续数字岛的长度和频率

我有一个1和0的序列,我想计算一下连续的1的岛出现的频率。

给定: S = [1 1 0 0 1 1 1 0 1 0 0 1 0 0 0 1 1 0 0 1 0 0 1 1 0 1]

通过计算连续的岛,我的意思是: R = [4 3 1] …因为有四个单岛,三个双岛和一个三连峰。

这样当乘以岛的长度[1 2 3]。

[4 3 1] * [1 2 3]' = 13

对应于sum(S) ,因为有13个。

我希望将解决方案向量化,而不是循环执行某些操作。

我想出了类似的东西: R = histcounts(diff( [0 (find( ~ (S > 0) ) ) numel(S)+1] ))

但是结果并没有多大意义。它计数了太多的三胞胎。我在互联网上找到的所有代码都与diff([0 something numel(S)])但问题始终略有不同,对我没有帮助

感谢您的任何建议!



更多&回答...
poster 当前离线   回复时引用此帖