【发布时间】:2012-10-31 08:05:15
【问题描述】:
我想确定列表是否包含任何重复元素,同时将排列视为等效。所有向量的长度相等。
完成此任务的最有效方法(最短运行时间)是什么?
## SAMPLE DATA
a <- c(1, 2, 3)
b <- c(4, 5, 6)
a.same <- c(3, 1, 2)
## BOTH OF THSE LISTS SHOULD BE FLAGGED AS HAVING DUPLICATES
myList1 <- list(a, b, a)
myList2 <- list(a, b, a.same)
# CHECK FOR DUPLICATES
anyDuplicated(myList1) > 0 # TRUE
anyDuplicated(myList2) > 0 # FALSE, but would like true.
现在我在检查重复项之前对列表中的每个成员进行排序
anyDuplicated( lapply(myList2, sort) ) > 0
我想知道是否有更有效的选择。此外,在?duplicated 文档中,它表示“将其用于列表可能会很慢”。还有其他更适合列表的函数吗?
【问题讨论】:
标签: r list duplicates