我有一个命名的数字向量 vec
,然后按升序排序并保存在 objectvec_sort
中,如下所示。
vec <- c(1,1,1,2,3,1,5)
names(vec) <- letters[1:7]
vec
# a b c d e f g
# 1 1 1 2 3 1 5
str(vec)
# Named num [1:7] 1 1 1 2 3 1 5
# - attr(*, "names")= chr [1:7] "a" "b" "c" "d" ...
按升序排序(命名数字向量)
vec_sort <- sort(vec)
vec_sort
# a b c f d e g
# 1 1 1 1 2 3 5
str(vec_sort)
# Named num [1:7] 1 1 1 1 2 3 5
# - attr(*, "names")= chr [1:7] "a" "b" "c" "f" ...
需要输出
一个命名逻辑向量,其中在升序数字向量的前 3 个元素中TRUE
,其余元素FALSE
。即使第 4 个元素与前 3 个元素相同。即最低值。使用关系运算符或通过分配它可能是。
vec_sort
# a b c f d e g
# 1 1 1 1 2 3 5
至
vec_sort
# a b c f d e g
# TRUE TRUE TRUE FALSE FALSE FALSE FALSE
尝试的代码
第一
vec_sort[1:3] <- TRUE
vec_sort[4:length] <- FALSE
vec_sort
# a b c f d e g
# 1 1 1 0 0 0 0
不合逻辑_
str(vec_sort)
# Named num [1:7] 1 1 1 0 0 0 0
- attr(*, "names")= chr [1:7] "a" "b" "c" "f" ...
第二
vec_sort <= min(vec_sort)
# a b c f d e g
# TRUE TRUE TRUE TRUE FALSE FALSE FALSE
这里的第 4 个变量f
也出现了,TRUE
因为条件是这样设置的。它是最小值,但从最小值开始,我只想将前 3 名设置为TRUE
尝试了更多的逻辑条件,但是TRUE
如果我尝试将其分配给TRUE
或者FALSE
它结果是一个命名数字向量,希望 1 为 TRUE 和 0 为 FALSE,但它都导致前 4 个,但最终不是命名逻辑向量。