我在一行中有一个带有数值的数据格式。现在我要计算这些行的累积和,直到>= 1。如果达到这一点,所有这些行都打印为计数器,在每一行中写入其计数器的累计和,然后查找下一行的累积和。
应该是这样的:
value counter cumsum
0.3 1 0.9
0.3 1 0.9
0.3 1 0.9
0.3 2 0.4
0.1 2 0.4
2 3 2我的问题是如何告诉R停止累积和,如果>=大于1,有什么想法吗?提前谢谢你。
发布于 2022-03-09 18:20:16
我不知道我是否正确地理解了你的问题,但也许这里的这个问题是有帮助的:
value = round(runif(20, min = 0.1, max = 0.5), 1)
csumVec = numeric(length(value))
counterVec = numeric(length(value))
startIndex = 1
csum = 0
counter = 1
for(i in 1:length(value)) {
csum = csum + value[i]
if(csum > 1) {
counterVec[startIndex:i] = counter
csumVec[startIndex:i] = csum-value[i]
startIndex = i
counter = counter+1
csum = value[i]
}
if(i == length(value)) {
counterVec[startIndex:i] = counter
csumVec[startIndex:i] = csum
}
}
cbind(value, counterVec, csumVec)https://stackoverflow.com/questions/71413918
复制相似问题