数据结构与算法 数组和链表

简介: 数据结构与算法 数组和链表

数组

python 数组都是动态数组,长度是自动变化的,所以不需要数组的扩容操作,这也是python运行要比C,Java慢的原因之一

列表: 由于数组长度不可变导致实用性降低,创建了一种动态数组的数据结构,称为列表

所以严格意义来说,python里面的数组就是列表

列表的代码(硬要定义数组不可变化)

class MyList:
    def __init__(self):
        self.__capacity = 10
        self.__nums = [0] * self.__capacity
        self.__size = 0
        self.__extend_ratio: 2
    def size(self):
        return self.__size
    
    def capacity(self):
        return self.__capacity
    
    def get(self, index):
        if index < 0 or index > self.__size:
            raise IndexError('索引越界')
        return self.__nums[index]
        
    def set(self, index, val):
        if index < 0 or index > self.__size:
            raise IndexError('索引越界')
        self.__nums[index] = val
    
    def add(self, val):
        if self.__size == self.__capacity:
            self.__capacity *= self.__extend_ratio
        self.__nums[self.__size] = val
        self.__size += 1
    def insert(self, index, val):
        if index < 0 or index > self.__size:
            raise IndexError('索引越界')
        for i in range(index, self.__size-1):
            self.__nums[i+1] = self.__nums[i]
        
        self.__nums[i] = val
        self.__size += 1
    def remove(self, index):
        if index < 0 or index > self.__size:
            raise IndexError('索引越界')
        
        for i in range(index, self.__size-1):
            self.__nums[i] = self.__nums[i+1]
        
        self.__size -= 1
    
    def extend_capacity(self):
        self.__nums += [0]*self.__capacity*(self.__extend_ratio - 1)
        self.__capacity = len(self.__nums)

链表

链表的代码:

class ListNode:
  def __init__(self, value):
  self.value = value
  self.next = None
  self.prev = None

对比

重点

  • 数组和链表是两种基本的数据结构,分别代表数据在计算机内存中的两种存储方式:连续空间存储和离散空间存储。两者的特点呈现出互补的特性。
  • 数组支持随机访问、占用内存较少;但插入和删除元素效率低,且初始化后长度不可变。
  • 链表通过更改引用(指针)实现高效的节点插入与删除,且可以灵活调整长度;但节点访问效率低、占用内存较多。常见的链表类型包括单向链表、循环链表、双向链表。
  • 动态数组,又称列表,是基于数组实现的一种数据结构。它保留了数组的优势,同时可以灵活调整长度。列表的出现极大地提高了数组的易用性,但可能导致部分内存空间浪费。


目录
相关文章
|
4天前
|
存储
数据结构链表详解(不仅顺序表可以,我链表也可以)
数据结构链表详解(不仅顺序表可以,我链表也可以)
12 0
|
2天前
|
算法 搜索推荐 Java
滚雪球学Java(33):数组算法大揭秘:应用案例实战分享
【5月更文挑战第8天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
29 8
滚雪球学Java(33):数组算法大揭秘:应用案例实战分享
|
3天前
|
存储 Android开发 算法
Android技能树 — 数组,链表,散列表基础小结,android教程零基础入门
Android技能树 — 数组,链表,散列表基础小结,android教程零基础入门
|
5天前
|
搜索推荐 算法 Java
滚雪球学Java(29):数组长度和排序算法:让你的程序更高效
【5月更文挑战第4天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
13 0
滚雪球学Java(29):数组长度和排序算法:让你的程序更高效
|
5天前
|
存储 Java
深入浅出数据结构之链表
深入浅出数据结构之链表
|
5天前
|
存储 索引
深入浅出数据结构之数组
深入浅出数据结构之数组
|
5天前
|
存储 算法 Java
Java数据结构与算法-java数据结构与算法(二)
Java数据结构与算法-java数据结构与算法
122 1
|
5天前
|
机器学习/深度学习 存储 算法
数据结构与算法 动态规划(启发式搜索、遗传算法、强化学习待完善)
数据结构与算法 动态规划(启发式搜索、遗传算法、强化学习待完善)
14 1
|
5天前
|
存储 人工智能 算法
有哪些数据结构与算法是程序员必须要掌握的?——“数据结构与算法”
有哪些数据结构与算法是程序员必须要掌握的?——“数据结构与算法”
|
5天前
|
算法 调度 C++
[数据结构与算法]贪心算法(原理+代码)
[数据结构与算法]贪心算法(原理+代码)