我有一个这样的整数向量:
a <- c(2,3,4,1,2,1,3,5,6,3,2)
values<-c(1,2,3,4,5,6)
我想为我的向量中的每个唯一值(正在排序的唯一值)列出它们出现的位置。我想要的输出:
rep_indx<-data.frame(c(4,6),c(1,5,11),c(2,7,10),c(3),c(8),c(9))
最佳答案
split
非常适合这里,它返回 a
中每个唯一值的索引列表:
indList <- split(seq_along(a), a)
indList
# $`1`
# [1] 4 6
#
# $`2`
# [1] 1 5 11
#
# $`3`
# [1] 2 7 10
#
# $`4`
# [1] 3
#
# $`5`
# [1] 8
#
# $`6`
# [1] 9
您可以通过将值作为字符传递来访问索引,即:
indList[["1"]]
# [1] 4 6
关于R:如何在不使用循环的情况下找到按唯一向量排序的所有重复向量值的索引?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38128345/