热门标签 | 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)



推荐阅读
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • dotnet 通过 Elmish.WPF 使用 F# 编写 WPF 应用
    本文来安利大家一个有趣而且强大的库,通过F#和C#混合编程编写WPF应用,可以在WPF中使用到F#强大的数据处理能力在GitHub上完全开源Elmis ... [详细]
  • 本文探讨了在Java中实现系统托盘最小化的两种方法:使用SWT库和JDK6自带的功能。通过这两种方式,开发者可以创建跨平台的应用程序,使窗口能够最小化到系统托盘,并提供丰富的交互功能。 ... [详细]
  • 作为一名专业的Web前端工程师,掌握HTML和CSS的命名规范是至关重要的。良好的命名习惯不仅有助于提高代码的可读性和维护性,还能促进团队协作。本文将详细介绍Web前端开发中常用的HTML和CSS命名规范,并提供实用的建议。 ... [详细]
  • 本文介绍如何使用布局文件在Android应用中排列多行TextView和Button,使其占据屏幕的特定比例,并提供示例代码以帮助理解和实现。 ... [详细]
  • 本文将介绍网易NEC CSS框架的规范及其在实际项目中的应用。通过详细解析其分类和命名规则,探讨如何编写高效、可维护的CSS代码,并分享一些实用的学习心得。 ... [详细]
  • 华为USG基于源地址的多出口策略路由配置
    网络拓扑如下:组网情况:企业用户主要有技术部(VLAN10)和行政部(VLAN20),通过汇聚交换机连接到USG。企业分别通过两个不同运营商(ISP1和ISP2)连接到 ... [详细]
  • 本文介绍如何通过 JavaScript 实现一个基于鼠标坐标的 Tooltip 弹出层,详细解释了如何获取窗口和文档的尺寸及滚动位置,并优化了代码结构。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • 本文详细介绍了Python中函数的基本概念,包括函数的定义与调用、文档注释、参数传递(形参与实参)、返回值以及函数嵌套。通过具体示例和解释,帮助读者掌握函数在编程中的应用。 ... [详细]
  • 深入解析Redis内存对象模型
    本文详细介绍了Redis内存对象模型的关键知识点,包括内存统计、内存分配、数据存储细节及优化策略。通过实际案例和专业分析,帮助读者全面理解Redis内存管理机制。 ... [详细]
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社区 版权所有