热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

查找向量中最后一次出现的唯一元素的索引

我有一个无序的向量

我有一个无序的向量

1
v

,如下所示,并希望找到列表中每个唯一元素的最后一个出现的索引。

1
2
3
4
5
v <- scan(text="1 2 1 2 1 1 1 3 1 2 2 3 3 3 1 1 1 4 1 1 1 4 1 5 5 6

                6 2 3 3 4 4 2 2 2 2 2 3 3 3 1 4 4 4 3 2 5 5 5 5")

v

# [1] 1 2 1 2 1 1 1 3 1 2 2 3 3 3 1 1 1 4 1 1 1 4 1 5 5 6 6 2 3 3 4 4 2 2 2 2 2 3 3 3

# [41] 1 4 4 4 3 2 5 5 5 5

预期结果(按1,2,3,4,5的顺序):

1
41 46 45 44 50

我知道我可以

1
unique(unlist(v))

用来找到独特的元素但是如何找到它们最后一次出现的指数?任何的想法?

提前致谢。


1
rle

如果

1
vector

已经订购,您可以尝试。提取长度(

1
$lengths)

然后

1
cumsum

。正如我之前提到的,如果它没有被排序,这将不起作用(再次取决于你真正想要的东西)。基本上

1
rle

通过检查一段中相似的连续元素的数量来工作。它将在列表中给出

1
lengths

和对应

1
values

1
2
cumsum(rle(v1)$lengths)

#[1] 28 37 42 46 50

另一个选择是按向量对序列进行分组,并获取

1
max

每个序列的值

1
group

。我想这会很慢。

1
2
unname(cumsum(tapply(seq_along(v1),v1, FUN=which.max)))    

#[1] 28 37 42 46 50

或者只是检查前值是否相同的电流值,然后插入

1
TRUE

作为最后一个元素,并获得该指数

1
TRUE

1
which

1
2
 which(c(v1[-1]!=v1[-length(v1)],TRUE))

 #[1] 28 37 42 46 50

或者使用

1
match

1
2
 c(match(unique(v1),v1)-1, length(v1))[-1]

#[1] 28 37 42 46 50

或者使用

1
findInterval

1
2
 findInterval(unique(v1), v1)

 #[1] 28 37 42 46 50


更新

对于新的载体

1
v2

1
2
max.col(t(sapply(unique(v2), `==`, v2)),&#x27;last&#x27;)

#[1] 41 46 45 44 50 27

或者在无序向量

1
findInterval

之后使用的函数

1
ordering

1
2
3
4
5
6
7
8
   f1 <- function(v){

      v1 <- setNames(v, seq_along(v))

      ind <- order(v1)

      as.numeric(names(v1[ind][findInterval(unique(v1), v1[ind])]))

    }    



 f1(v2)

 #[1] 41 46 45 44 50 27

使用

1
z

@Marat talipov帖子中的例子(),

1
2
 f1(z)

 #[1] 4 5 3

注意:我按照唯一元素首次出现的顺序得到结果

1
z

。即

1
1

,然后

1
3

1
2

。如果需要根据值再次订购,可以使用

1
order

(如@Marat Talipov所述)。但是,目前尚不清楚OP在这种情况下真正想要的是什么。

数据

1
2
3
4
5
6
7
8
9
v1 <- c(1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,

 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3,

 3, 4, 4, 4, 4, 5, 5, 5, 5)



v2 <-  c(1, 2, 1, 2, 1, 1, 1, 3, 1, 2, 2, 3, 3, 3, 1, 1, 1, 4, 1, 1,

 1, 4, 1, 5, 5, 6, 6, 2, 3, 3, 4, 4, 2, 2, 2, 2, 2, 3, 3, 3, 1,

 4, 4, 4, 3, 2, 5, 5, 5, 5)



 z <- c(1, 3, 2, 1, 3)



推荐阅读
author-avatar
UP7家族--婵婵_172
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有