作者:kingseao | 来源:互联网 | 2023-10-12 10:15
样本数据
batch <- c(rep(1,3), rep(2,4), rep(3,5))
batch
[1] 1 1 1 2 2 2 2 3 3 3 3 3
alpha <- c(0.05, 0.04, 0.03)
问题陈述
我想创建一个向量,比如说alphai
,alpha
它在batch
给定值处重复出现次数的第 i 个元素(例如,对于批次 = 1,应该重复 alpha 的第一个值 1 出现的次数) . 所需的输出应如下所示:
alpha
[1] 0.05 0.05 0.05 0.04 0.04 0.04 0.04 0.03 0.03 0.03 0.03 0.03
请提供仅基于 R 的解决方案,谢谢!
编辑
我希望提供的代码在批处理情况下工作,其中批处理可以是非递增序列或非连续序列(即 1、3、4、5 等)
batch2 <- c(rep(1,3), rep(3, 4), rep(4,5))
batch2
[1] 1 1 1 3 3 3 3 4 4 4 4 4
alpha
应该还是
[1] 0.05 0.05 0.05 0.04 0.04 0.04 0.04 0.03 0.03 0.03 0.03 0.03
回答
该索引可用于复制。在 中R
,索引从 1 开始。因此,如果我们指定多个 1,它会多次从第 1 个位置提取 'alpha' 对象中的元素,其他索引类似。请注意,索引 0 将被跳过,因为没有元素
alpha[batch]