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



推荐阅读
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ... [详细]
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文探讨了如何在编程中正确处理包含空数组的 JSON 对象,提供了详细的代码示例和解决方案。 ... [详细]
  • 本文详细介绍了 com.facebook.drawee.view.SimpleDraweeView 中的 setScaleType 方法,提供了多个实际代码示例,并解释了其在不同场景下的应用。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • dotnet 通过 Elmish.WPF 使用 F# 编写 WPF 应用
    本文来安利大家一个有趣而且强大的库,通过F#和C#混合编程编写WPF应用,可以在WPF中使用到F#强大的数据处理能力在GitHub上完全开源Elmis ... [详细]
  • 作为一名专业的Web前端工程师,掌握HTML和CSS的命名规范是至关重要的。良好的命名习惯不仅有助于提高代码的可读性和维护性,还能促进团队协作。本文将详细介绍Web前端开发中常用的HTML和CSS命名规范,并提供实用的建议。 ... [详细]
  • 本文介绍如何使用布局文件在Android应用中排列多行TextView和Button,使其占据屏幕的特定比例,并提供示例代码以帮助理解和实现。 ... [详细]
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社区 版权所有