如何解决区分和计数 0 和 1 序列中的事件的最有效方法是什么?
test = c(0,1,0)
事件由 0 的子序列中的第一个 0 定义。我对每个事件中零的数量(计数)感兴趣。
对于上面的测试,我们会:
- 事件 1:0 0 0
- 事件 2:0
- 事件 3:0 0
所以,我想创建下表,
活动 | 计数 |
---|---|
1 | 3 |
2 | 1 |
3 | 2 |
我已经开始创建一个带有 if 子句的函数。但是使用我正在使用的长向量运行变得太重了。
然后我用 dplyr 开始了一个新代码,但我无法让它正常工作。
最有效的方法是什么?
这是我的示例(和不正确的)代码:
library(dplyr)
test = c(0,0)
df = data.frame(test)
df$cumsum = cumsum(df$test==0L)
df%>%
group_by(test,cumsum)%>%
mutate(counter=row_number())%>%
ungroup
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。