数据结构---列表与数组

1.列表是如何存储的?

  列表是一块连续的内存空间,上一个数下一个数是连续的

  列表叫动态表,数组叫线性表

2.列表可以做哪些操作?

  根据索引查(读)、改(写)  -----  时间复杂度O(1)

  删除,插入(最后一位删除pop或插入append,时间复杂度是O(1))---- 时间复杂度O(n)

2. 列表在其他语言中叫 ”数组“,”数组“较列表底层,他们的区别:

    int a[5]:

    数组的长度是固定的,在声明时就要设定它的长度,不能追加,而列表长度不固定,可以随意append

    数组中存放的数据必须是相同的,要是字符串(整数、对象)就都是字符串(整数、对象),而列表没有这个要求,可以既要字符串,又有整数、对象等数据类型。

3. 说说数组:

  (1)数组是一块连续的内存空间

  (2)列表叫动态表,数组叫线性表

  (3)根据索引查(读)、改(写)  -----  时间复杂度O(1)

      删除,插入(最后一位删除pop()或插入append(),时间复杂度是O(1))---- 时间复杂度O(n)

  (4)增加数据:长度是固定的,那要想数组长度变长怎么办?再申请一块更大的内存空间,把之前的数组copy过来,然后把之前的内存空间释放掉就可以了。时间复杂度是O(1)

  (5)修改数据:存放的数据必须相同,要是不想相同呢,不直接在内存中存数据,把每个数据存到不同的内存地址中,把每个内存地址存放到内存中。此时要想修改数据,就不能按照索引来改了,而是应该再开辟一块内存空间,将数据存进去,再将该内存地址存放到内存中,将之前数据的内存地址覆盖掉。

  

 

转载于:https://www.cnblogs.com/yanyufeng/p/9852299.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会为你介绍Python数组。 在Python数组是一种存储元素的数据结构。与列表不同,数组是固定大小的,且元素类型必须相同。 要使用数组,需要先导入array模块。下面是一个创建数组的示例: ```python import array as arr # 创建一个整数类型的数组 a = arr.array('i', [1, 2, 3, 4, 5]) # 打印数组 print(a) ``` 在上面的示例,我们使用了`array`模块创建了一个整数类型的数组,并初始化了它。要注意的是,第一个参数是一个字符,用于指定数组元素的类型。在本例,我们使用了`i`,表示整数类型。 除了整数类型之外,还有其他类型可以使用,如`f`表示浮点数,`d`表示双精度浮点数,`b`表示布尔类型等。 在数组,可以使用索引来访问元素,如下所示: ```python import array as arr # 创建一个整数类型的数组 a = arr.array('i', [1, 2, 3, 4, 5]) # 访问数组的第一个元素 print(a[0]) # 修改数组的第二个元素 a[1] = 6 # 打印数组 print(a) ``` 在上面的示例,我们使用了索引`0`来访问数组的第一个元素,使用索引`1`来修改数组的第二个元素。 除了使用索引来访问和修改元素外,还可以使用循环来遍历数组的所有元素,如下所示: ```python import array as arr # 创建一个整数类型的数组 a = arr.array('i', [1, 2, 3, 4, 5]) # 遍历数组的所有元素 for i in a: print(i) ``` 在上面的示例,我们使用了`for`循环来遍历数组的所有元素,并打印每个元素的值。 这就是Python数组的基本用法。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值