R语言数据结构-----列表

这篇具有很好参考价值的文章主要介绍了R语言数据结构-----列表。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

(1)创建列表

 (2)列表索引

(3)增加或删除列表元素

(4)访问列表元素和值

(5)apply()函数

(6)递归型列表


列表的基本操作

> x<-list(u=2,v="abc")
> x
$u
[1] 2

$v
[1] "abc"

> x$u
[1] 2

函数hist()中的数据,也是通过列表保存的

> hn<-hist(Nile)
> print(hn)
$breaks
 [1]  400  500  600  700  800  900 1000 1100 1200 1300 1400

$counts
 [1]  1  0  5 20 25 19 12 11  6  1

$density
 [1] 0.0001 0.0000 0.0005 0.0020 0.0025 0.0019 0.0012 0.0011 0.0006
[10] 0.0001

$mids
 [1]  450  550  650  750  850  950 1050 1150 1250 1350

$xname
[1] "Nile"

$equidist
[1] TRUE

attr(,"class")
[1] "histogram"

#也可以用
> str(hn)
List of 6
 $ breaks  : int [1:11] 400 500 600 700 800 900 1000 1100 1200 1300 ...
 $ counts  : int [1:10] 1 0 5 20 25 19 12 11 6 1
 $ density : num [1:10] 0.0001 0 0.0005 0.002 0.0025 0.0019 0.0012 0.0011 0.0006 0.0001
 $ mids    : num [1:10] 450 550 650 750 850 950 1050 1150 1250 1350
 $ xname   : chr "Nile"
 $ equidist: logi TRUE
 - attr(*, "class")= chr "histogram"

(1)创建列表
#列表中各组件的名称叫标签
> j<-list(name="Joe",salary=55000,union=T)
> j
$name
[1] "Joe"

$salary
[1] 55000

$union
[1] TRUE

#标签是可选的,也可以不指定
> jalt<-list("Joe",55000,T)
> jalt
[[1]]
[1] "Joe"

[[2]]
[1] 55000

[[3]]
[1] TRUE
#但是一般来说推荐为各个部分取名而不用默认的数值,这样使得代码更加清晰

#在使用时可以使用简称,只要不引起歧义
> j$sal
[1] 55000

#因为列表是向量,所以可以用vector()创建列表
> z[["abc"]]<-3
> z
$abc
[1] 3
 (2)列表索引
> j$salary
[1] 55000
> j[["salary"]]
[1] 55000
#可以用数字索引访问列表中的组件,但是要用双重中括号
> j[[2]]
[1] 55000

[]用于提取子集:[]可以用来提取数据结构中的一个或多个元素,并返回一个与原始结构类型相匹配的新结构
> j[2]
$salary
[1] 55000


[[]]用于提取单个元素或子列表:[[]]一次只能提取列表的一个组件,返回值是组件本身的类型,而不是列表
> j[[2]]
[1] 55000

#只能提取列表中的一个组件
> j[[1:2]]
Error in j[[1:2]] : subscript out of bounds
> j2a<-j[[2]]
> j2a
[1] 55000
> class(j2a)
[1] "numeric"

> j[1:2]
$name
[1] "Joe"

$salary
[1] 55000

> class(j2)
[1] "list"
> str(j2)
List of 1
 $ salary: num 55000
(3)增加或删除列表元素

添加新的组件

> z<-list(a="abc",b=12)
> z
$a
[1] "abc"

$b
[1] 12

> z$c <- "sailing" 
> z
$a
[1] "abc"

$b
[1] 12

$c
[1] "sailing"

使用索引添加组件

> z<-list(a="abc",b=12)
> z[[4]]<-28
> z[5:7]<-c(FALSE,TRUE,TRUE)

> z
$a
[1] "abc"

$b
[1] 12

[[3]]
NULL

[[4]]
[1] 28

[[5]]
[1] FALSE

[[6]]
[1] TRUE

[[7]]
[1] TRUE

删除列表元素可以直接把它的值设为NULL

#删除z$b之后,它之后的元素索引全部减1,例如原来的z[[4]]变成了z[[3]]
> z$b<-NULL
> z
$a
[1] "abc"

[[2]]
NULL

[[3]]
[1] 28

[[4]]
[1] FALSE

[[5]]
[1] TRUE

[[6]]
[1] TRUE


#把多个列表拼接成一个
> c(list("Joe","55000",T),list(5))
[[1]]
[1] "Joe"

[[2]]
[1] "55000"

[[3]]
[1] TRUE

[[4]]
[1] 5

获取列表长度

> length(j)
[1] 3
(4)访问列表元素和值

如果一个列表的各元素含有标签,就可以使用names()获取它的标签

#如果一个列表的各元素含有标签,就可以使用names()获取它的标签
> names(j)
[1] "name"   "salary" "union" 

#使用unlist()来获取列表的值
#unlist()返回的值是一个向量---这里返回的是一个字符串向量,而且向量的元素名就来自原列表的标签
> ulj<-unlist(j)
> ulj
   name  salary   union 
  "Joe" "55000"  "TRUE" 
> class(ulj)
[1] "character"

#如果列表中都是数值,unlist()返回的就是数值向量
> z<-list(a=5,b=12,c=13)
> y<-unlist(z)
> class(y)
[1] "numeric"
> y
 a  b  c 
 5 12 13 

#如果列表中既有字符串又有数值
#混合类型的数值下R选择了这些类型中能最大程度地保留它们共同特性的类型:字符串
#各种类型的优先级排序
NULL<raw<逻辑类型<整型<实数类型<复数类型<列表<表达式
> w<-list(a=5,b="xyz")
> wu<-unlist(w)
> class(wu)
[1] "character"
> wu
    a     b 
  "5" "xyz" 

重点

#各种类型的优先级排序
NULL<raw<逻辑类型<整型<实数类型<复数类型<列表<表达式

 如果把向量元素名称赋值为NULL,可以将其移除

> x<-c(1,2,4)
> names(x)
NULL
> names(x)<-c("a","b","ab")
> names(x)
[1] "a"  "b"  "ab"
> x
 a  b ab 
 1  2  4 

#把向量元素名称赋值为NULL,可以将其移除
> names(x)<-NULL
> x
[1] 1 2 4

#用名称来引用向量中的元素
> x<-c(1,2,4)
> names(x)<-c("a","b","ab")
> x["b"]
b 

> w<-list(a=5,b="xyz")
> wu<-unlist(w)
> names(wu)<-NULL
> wu
[1] "5"   "xyz"

#unname()函数直接去掉元素名
> wun<-unname(wu)
> wun
[1] "5"   "xyz"
(5)apply()函数

lapply()(代表list apply)与矩阵的apply()函数相似,对列表的每个组件执行特定的函数
并返回另外一个列表

> lapply(list(1:3,25:29),median)
[[1]]
[1] 2

[[2]]
[1] 27

 lapply()返回的列表可以转化为矩阵或向量的形式

sapply()(代表simplified[l]apply)文章来源地址https://www.toymoban.com/news/detail-709604.html

> sapply(list(1:3,25:29), median)
[1]  2 27

> z<-function(z)
+ return (c(z,z^2))
> sapply(1:8,z)
     [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8]
[1,]    1    2    3    4    5    6    7    8
[2,]    1    4    9   16   25   36   49   64

(6)递归型列表
#生成包含两个组件的列表,每个组件本事都是列表
> b<-list(u=5,v=12)
> c<-list(w=13)
> a<-list(b,c)
> a
[[1]]
[[1]]$u
[1] 5

[[1]]$v
[1] 12


[[2]]
[[2]]$w
[1] 13


> length(a)
[1] 2


> c(list(a=1,b=2,c=list(d=5,e=9)))
$a
[1] 1

$b
[1] 2

$c
$c$d
[1] 5

$c$e
[1] 9

#recursive默认为FALSE,得到一个递归型列表,其中组件c是另外一个列表
#recursive=TRUE,得到的是向量,只有名称还带有原来递归的特征
> c(list(a=1,b=2,c=list(d=5,e=9)),recursive=T)
  a   b c.d c.e 
  1   2   5   9 

到了这里,关于R语言数据结构-----列表的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构基础--散列表

    散列表,又叫 哈希表 (Hash Table),是能够通过给定的的值直接访问到具体对应的值的一个数据结构。也就是说,把映射到一个表中的位置来直接访问记录,以加快访问速度。 通常,把这个称为 Key,把对应的记录称为 Value,所以也可以说是通过 Key 访问

    2024年02月04日
    浏览(32)
  • 数据结构—散列表的查找

    7.4散列表的查找 7.4.1散列表的基本概念 基本思想:记录的存储位置域之间存在对应关系 ​ 对应关系——hash函数 ​ Loc(i)= H(keyi) 如何查找 : 根据散列函数 H(key) = k 查找key=9,则访问H(4)= 18号地址,若内容为18则成功; 若查不到,则返回一个特殊值,如空指针或

    2024年02月12日
    浏览(31)
  • 哈希表-散列表数据结构

    哈希表也叫散列表,哈希表是根据关键码值(key value)来直接访问的一种数据结构,也就是将关键码值(key value)通过一种映射关系映射到表中的一个位置来加快查找的速度,这种映射关系称之为哈希函数或者散列函数,存放记录的数组称之为哈希表。 哈希表采用的是一种转换思

    2024年01月21日
    浏览(43)
  • Linux内核数据结构 散列表

    在Linux内核中,散列表(哈希表)使用非常广泛。本文将对其数据结构和核心函数进行分析。和散列表相关的数据结构有两个: hlist_head 和 hlist_node 对应的结构如下 hash_table 为散列表(数组),其中的元素类型为 struct hlist_head 。以 hlist_head 为链表头的链表,其中的节点 hash 值

    2024年02月10日
    浏览(30)
  • 数据结构——散列函数、散列表

    散列表的基本概念 散列函数的构造方法 处理冲突的方法 散列查找及性能分析 提示:以下是本篇文章正文内容,下面案例可供参考 概念:之前的算法建立在“比较”基础上,效率取决于比较次数 散列函数:将映射成该对应地址的函数,记为Hash(key)=Addr,散列函

    2024年02月07日
    浏览(32)
  • 数据结构——带头节点的双向循环列表

    带头节点的双向循环链表 是一种特殊的双向链表,它与普通的双向链表相比,最大的区别是链表头结点的 next 指针不再指向第一个实际节点,而是指向链表中的第一个节点。同时,链表尾结点的 prev 指针也不再指向 NULL,而是指向链表中的最后一个节点。 另外, 带头节点的

    2024年02月11日
    浏览(34)
  • Python列表:灵活多变的数据结构

    在Python 3中,列表是一种有序的集合,它包含了多个元素并且每个元素可以是任意类型的数据。列表使用方括号 [ ] 来表示,其中的元素由逗号 , 分隔开。 首先,我们可以创建一个空的列表: 然后,我们创建一个包含多个元素的列表 序列中的每个值都有对应的位置值,称之为

    2024年02月21日
    浏览(31)
  • 数据结构算法设计——哈希表(散列表)

            哈希表 又叫 散列表 ,他们两个是同一个东西,本文全文采用“散列表”的叫法。散列表的本质其实就是一个 数组 ,他的作用就像使用数组时一样,输入下标可以得到对应元素,散列表可以实现 输入一个的时候得到这个的地址信息 。 下面是百科给出

    2024年02月03日
    浏览(51)
  • 【数据结构】——查找、散列表的相关习题

    1、顺序查找适用于存储结构为()的线性表。 A、顺序存储结构或者链式存储结构 B、散列存储结构 C、索引存储结构 D、压缩存储结构 解析: (A) 顺序查找 属于线性查找,从线性表的一端开始,依次检查所给定的是否满足条件,若找到符合条件的元素,则查找成功

    2024年02月04日
    浏览(37)
  • Redis数据结构——快速列表quicklist、快表

    Redis中的数据结构,链表和压缩列表这两种数据结构是列表对象的底层实现方式。 当时考虑到链表的附加空间太大,节点的内存都是单独分配的,还会导致内存碎片化问题严重。 因此从Redis3.2开始,对列表的底层数据结构进行了改造,即使用 quickList代替链表list和压缩列表z

    2024年02月12日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包