【发布时间】:2015-08-21 22:34:26
【问题描述】:
让我们假设以下示例:
test<-c(1:5,3:7)
给了
test
[1] 1 2 3 4 5 3 4 5 6 7
我想要一个简单的函数,如果值在向量中是唯一的,则返回 TRUE。
[1] TRUE TRUE FALSE FALSE FALSE FALSE FALSE FALSE TRUE TRUE
我尝试了什么:
unique(test) 只给我返回唯一值,包括那些重复的值。
duplicated(test) 还给我
[1] FALSE FALSE FALSE FALSE FALSE TRUE TRUE TRUE FALSE FALSE
这显然不是必需的结果,因为函数会按顺序测试重复的观察结果,并且第一次出现不计为重复。我当然可以通过包含fromLast = T 来反转控制序列并创建两个向量。在这两个中,我可以创建第三个来表示真正的独特价值……但这相当复杂。
table(test) 允许我计算每个值的出现次数
test
1 2 3 4 5 6 7
1 1 2 2 2 1 1
这使我更接近我想要的结果,但仍然不是所需的结果(相同长度的向量表明它在向量中是否唯一。)
所以有人知道如何更容易吗?
【问题讨论】: