爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      数据结构与算法实现(6/6)

      首页 知识中心 数据库 文章详情页

      数据结构与算法实现(6/6)

      2024-10-30 09:01:17 阅读次数:44

      数据结构,算法

      1. 引言

      1.1 数据结构与算法实现的重要性

      在计算机科学中,数据结构和算法的设计与实现是任何程序开发的核心部分。高效的数据结构和算法能够极大地提升程序的性能和响应速度,因此,理解并掌握这些内容对于程序员来说至关重要。实现数据结构和算法不仅仅是编写代码,还涉及到对时间复杂度和空间复杂度的分析,以及对代码可读性和可维护性的考虑。

      1.2 实现数据结构与算法的基本原则

      在实现数据结构与算法时,应遵循以下基本原则:

      • 选择合适的数据结构:不同的数据结构在不同的应用场景中有不同的优劣势,应根据具体需求选择最优的数据结构。
      • 优化时间和空间复杂度:在实现过程中,始终关注算法的时间复杂度和空间复杂度,尽可能降低其复杂度。
      • 确保代码的可读性和可维护性:编写的代码应当易于理解和维护,避免过度复杂的实现。
      • 测试和验证:实现后的数据结构和算法应经过充分的测试,确保其正确性和效率。

      2. 线性表的实现

      线性表是最基础的数据结构之一,可以通过多种方式实现,包括顺序表、链表、静态链表和动态链表。

      2.1 顺序表的实现

      顺序表(Array List)是最常见的线性表实现之一,使用数组来存储元素。顺序表的特点是能够支持快速的随机访问,但插入和删除操作的效率较低。

      class ArrayList:
          def __init__(self, capacity=10):
              self.array = [None] * capacity
              self.size = 0
      
          def insert(self, index, value):
              if self.size == len(self.array):
                  self.resize(2 * len(self.array))
              for i in range(self.size, index, -1):
                  self.array[i] = self.array[i - 1]
              self.array[index] = value
              self.size += 1
      
          def delete(self, index):
              if index < 0 or index >= self.size:
                  raise IndexError('Index out of bounds')
              for i in range(index, self.size - 1):
                  self.array[i] = self.array[i + 1]
              self.array[self.size - 1] = None
              self.size -= 1
      
          def resize(self, new_capacity):
              new_array = [None] * new_capacity
              for i in range(self.size):
                  new_array[i] = self.array[i]
              self.array = new_array
      

      2.2 链表的实现

      链表(Linked List)是一种动态数据结构,通过节点(Node)的链式连接实现。与顺序表相比,链表的插入和删除操作更高效,但随机访问性能较差。

      class Node:
          def __init__(self, value=None):
              self.value = value
              self.next = None
      
      class LinkedList:
          def __init__(self):
              self.head = None
      
          def insert_at_beginning(self, value):
              new_node = Node(value)
              new_node.next = self.head
              self.head = new_node
      
          def insert_at_end(self, value):
              new_node = Node(value)
              if not self.head:
                  self.head = new_node
                  return
              last_node = self.head
              while last_node.next:
                  last_node = last_node.next
              last_node.next = new_node
      
          def delete_node(self, value):
              temp = self.head
              if temp is not None:
                  if temp.value == value:
                      self.head = temp.next
                      temp = None
                      return
              while temp is not None:
                  if temp.value == value:
                      break
                  prev = temp
                  temp = temp.next
              if temp == None:
                  return
              prev.next = temp.next
              temp = None
      

      2.3 静态链表与动态链表的实现

      静态链表使用数组来存储节点,同时用指针表示节点之间的连接关系。这种实现方式可以避免动态内存分配的开销,但灵活性较低。

      class StaticLinkedList:
          def __init__(self, max_size):
              self.array = [None] * max_size
              self.next = [-1] * max_size
              self.head = -1
              self.size = 0
      
          def insert(self, index, value):
              if self.size == len(self.array):
                  raise Exception("List is full")
              new_node = self.size
              self.array[new_node] = value
              self.next[new_node] = self.head
              self.head = new_node
              self.size += 1
      
          def delete(self, value):
              prev = -1
              current = self.head
              while current != -1 and self.array[current] != value:
                  prev = current
                  current = self.next[current]
              if current == -1:
                  return
              if prev == -1:
                  self.head = self.next[current]
              else:
                  self.next[prev] = self.next[current]
              self.size -= 1
      

      动态链表与传统链表相似,可以根据需要动态调整大小,通常通过堆内存分配来实现。

      3. 栈与队列的实现

      栈和队列是两种常见的线性数据结构,在很多算法中都有广泛应用。

      3.1 顺序栈与链栈的实现

      顺序栈使用数组实现,具有固定大小,操作简单。

      class ArrayStack:
          def __init__(self, capacity=10):
              self.array = [None] * capacity
               = -1
      
          def push(self, value):
              if  == len(self.array) - 1:
                  raise Exception("Stack Overflow")
               += 1
              self.array[] = value
      
          def pop(self):
              if  == -1:
                  raise Exception("Stack Underflow")
              value = self.array[]
              self.array[] = None
               -= 1
              return value
      

      链栈则使用链表实现,大小不受限制。

      class LinkedStack:
          def __init__(self):
              self.head = None
      
          def push(self, value):
              new_node = Node(value)
              new_node.next = self.head
              self.head = new_node
      
          def pop(self):
              if not self.head:
                  raise Exception("Stack Underflow")
              value = self.head.value
              self.head = self.head.next
              return value
      

      3.2 顺序队列与链队列的实现

      顺序队列使用数组实现,支持先进先出(FIFO)的操作。

      class ArrayQueue:
          def __init__(self, capacity=10):
              self.array = [None] * capacity
              self.front = 0
              self.rear = 0
      
          def enqueue(self, value):
              if (self.rear + 1) % len(self.array) == self.front:
                  raise Exception("Queue Overflow")
              self.array[self.rear] = value
              self.rear = (self.rear + 1) % len(self.array)
      
          def dequeue(self):
              if self.front == self.rear:
                  raise Exception("Queue Underflow")
              value = self.array[self.front]
              self.array[self.front] = None
              self.front = (self.front + 1) % len(self.array)
              return value
      

      链队列使用链表实现,支持灵活的动态调整。

      class LinkedQueue:
          def __init__(self):
              self.front = self.rear = None
      
          def enqueue(self, value):
              new_node = Node(value)
              if self.rear is None:
                  self.front = self.rear = new_node
                  return
              self.rear.next = new_node
              self.rear = new_node
      
          def dequeue(self):
              if self.front is None:
                  raise Exception("Queue Underflow")
              value = self.front.value
              self.front = self.front.next
              if self.front is None:
                  self.rear = None
              return value
      

      3.3 循环队列与双端队列的实现

      循环队列是一种特别的队列实现方式,使用循环数组来优化空间利用率。

      class CircularQueue:
          def __init__(self, capacity=10):
              self.array = [None] * capacity
              self.front = 0
              self.rear = 0
              self.size = 0
      
          def enqueue(self, value):
              if self.size == len(self.array):
                  raise Exception("Queue Overflow")
              self.array[self.rear] = value
              self.rear = (self.rear + 1) % len(self.array)
              self.size += 1
      
          def dequeue(self):
              if self.size == 0:
                  raise Exception("Queue Underflow")
              value = self.array[self.front]
              self.front = (self.front + 1) % len(self.array)
              self.size -= 1
              return value
      

      双端队列(Deque)允许在队列的两端进行插入和删除操作。

      class Deque:
          def __init__(self, capacity=10):
              self.array = [None] * capacity
              self.front = 0
              self.rear = 0
              self.size = 0
      
          def add_front(self, value):
              if self.size == len(self.array):
                  raise Exception("Deque Overflow")
              self.front = (self.front - 1) % len(self.array)
              self.array[self.front] = value
              self.size += 1
      
          def add_rear(self, value):
              if self.size == len(self.array):
                  raise Exception("Deque Overflow")
              self.array[self.rear] = value
              self.rear = (self.rear + 1) % len(self.array)
              self.size += 1
      
          def remove_front(self):
              if self.size == 0:
                  raise Exception("Deque Underflow")
              value = self.array[self.front]
              self.front = (self.front + 1) % len(self.array)
              self.size -= 1
              return value
      
          def remove_rear(self):
              if self.size == 0:
                  raise Exception("Deque Underflow")
              self.rear = (self.rear - 1) % len(self.array)
              value = self.array[self.rear]
              self.size -= 1
              return value
      

      4. 树的实现

      树是一种层次数据结构,用于表示具有层次关系的数据。最常用的树结构包括二叉树、平衡树和哈夫曼树。

      4.1 二叉树的实现

      二叉树是每个节点最多有两个子节点的树结构。常用的二叉树类型包括二叉搜索树(BST),其实现如下:

      class TreeNode:
          def __init__(self, key):
              self.left = None
              self.right = None
              self.val = key
      
      class BinarySearchTree:
          def __init__(self):
              self.root = None
      
          def insert(self, key):
              if self.root is None:
                  self.root = TreeNode(key)
              else:
                  self._insert(self.root, key)
      
          def _insert(self, node, key):
              if key < node.val:
                  if node.left is None:
                      node.left = TreeNode(key)
                  else:
                      self._insert(node.left, key)
              else:
                  if node.right is None:
                      node.right = TreeNode(key)
                  else:
                      self._insert(node.right, key)
      
          def search(self, key):
              return self._search(self.root, key)
      
          def _search(self, node, key):
              if node is None or node.val == key:
                  return node
              if key < node.val:
                  return self._search(node.left, key)
              return self._search(node.right, key)
      

      4.2 平衡树的实现

      平衡树是一种通过自动调整节点高度来保持树的平衡的树结构,最常见的平衡树包括AVL树和红黑树。

      AVL树的实现通过在每次插入或删除节点后检查树的平衡因子,并进行必要的旋转来保持树的平衡。

      4.3 哈夫曼树的实现

      哈夫曼树是一种用于数据压缩的二叉树,通过最小化编码总长度来实现最优压缩。其实现过程包括:

      1. 创建节点:将所有字符作为叶节点,按频率排序。
      2. 构建树:每次从优先队列中取出频率最小的两个节点,合并为一个新的父节点,重新插入队列。
      3. 生成编码:遍历哈夫曼树,分配0和1来生成二进制编码。
      import heapq
      
      class HuffmanNode:
          def __init__(self, freq, symbol, left=None, right=None):
              self.freq = freq
              self.symbol = symbol
              self.left = left
              self.right = right
      
          def __lt__(self, other):
              return self.freq < other.freq
      
      def huffman_tree(symbols):
          heap = [HuffmanNode(freq, symbol) for symbol, freq in symbols.items()]
          heapq.heapify(heap)
      
          while len(heap) > 1:
              left = heapq.heappop(heap)
              right = heapq.heappop(heap)
              merged = HuffmanNode(left.freq + right.freq, None, left, right)
              heapq.heappush(heap, merged)
      
          return heap[0]
      
      def generate_huffman_codes(node, prefix="", codebook={}):
          if node is not None:
              if node.symbol is not None:
                  codebook[node.symbol] = prefix
              generate_huffman_codes(node.left, prefix + "0", codebook)
              generate_huffman_codes(node.right, prefix + "1", codebook)
          return codebook
      

      5. 图的实现

      图是一种复杂的数据结构,由节点(顶点)和边组成,用于表示节点之间的关系。

      5.1 邻接矩阵与邻接表的实现

      邻接矩阵是一种二维数组,用于存储图中顶点之间的连接关系,适用于稠密图。

      class GraphAdjMatrix:
          def __init__(self, vertices):
              self.V = vertices
              self.graph = [[0] * vertices for _ in range(vertices)]
      
          def add_edge(self, u, v):
              self.graph[u][v] = 1
              self.graph[v][u] = 1
      

      邻接表是一种链表数组,用于存储每个顶点的邻接顶点,适用于稀疏图。

      class GraphAdjList:
          def __init__(self, vertices):
              self.V = vertices
              self.graph = [[] for _ in range(vertices)]
      
          def add_edge(self, u, v):
              self.graph[u].append(v)
              self.graph[v].append(u)
      

      5.2 图的遍历算法的实现

      深度优先搜索(DFS)和广度优先搜索(BFS)是图的两种基本遍历算法。

      def dfs(graph, vertex, visited=None):
          if visited is None:
              visited = set()
          visited.add(vertex)
          print(vertex, end=' ')
          for neighbor in graph[vertex]:
              if neighbor not in visited:
                  dfs(graph, neighbor, visited)
      
      def bfs(graph, start):
          visited = set()
          queue = [start]
          visited.add(start)
          while queue:
              vertex = queue.pop(0)
              print(vertex, end=' ')
              for neighbor in graph[vertex]:
                  if neighbor not in visited:
                      visited.add(neighbor)
                      queue.append(neighbor)
      

      5.3 最短路径与最小生成树的实现

      最短路径算法用于查找图中两点之间的最短路径,如Dijkstra算法和Bellman-Ford算法。

      import heapq
      
      def dijkstra(graph, start):
          distances = {vertex: float('infinity') for vertex in graph}
          distances[start] = 0
          pq = [(0, start)]
      
          while pq:
              current_distance, current_vertex = heapq.heappop(pq)
              if current_distance > distances[current_vertex]:
                  continue
              for neighbor, weight in graph[current_vertex].items():
                  distance = current_distance + weight
                  if distance < distances[neighbor]:
                      distances[neighbor] = distance
                      heapq.heappush(pq, (distance, neighbor))
      
          return distances
      

      最小生成树(MST)用于查找图中所有节点的最小连接树,如Prim算法和Kruskal算法。

      def prim_mst(graph):
          visited = set()
          mst = []
          edges = [(0, 0, 0)]
          while edges:
              weight, u, v = heapq.heappop(edges)
              if v not in visited:
                  visited.add(v)
                  mst.append((u, v, weight))
                  for neighbor, weight in graph[v].items():
                      if neighbor not in visited:
                          heapq.heappush(edges, (weight, v, neighbor))
          return mst
      

      6. 算法设计与优化

      算法设计与优化是提高程序性能的关键,包括递归、分治、动态规划、贪心算法等策略。

      6.1 算法设计的基本原则与方法

      设计算法时应遵循以下原则:

      • 简洁:算法应简单易懂,避免不必要的复杂性。
      • 高效:算法应尽量减少时间和空间复杂度。
      • 通用:算法应具有广泛的适用性,能够处理不同类型的问题。

      6.2 递归与分治策略的应用

      递归是解决问题的常用方法,通过将问题分解为相似的子问题,递归地解决每个子问题。分治策略是递归的扩展,通过将问题分解为多个独立的子问题,然后合并子问题的解来解决原问题。

      def quicksort(arr):
          if len(arr) <= 1:
              return arr
          pivot = arr[len(arr) // 2]
          left = [x for x in arr if x < pivot]
          middle = [x for x in arr if x == pivot]
          right = [x for x in arr if x > pivot]
          return quicksort(left) + middle + quicksort(right)
      

      6.3 动态规划与贪心算法的实现与优化

      动态规划用于解决具有重叠子问题的最优化问题,通过保存子问题的解来避免重复计算。贪心算法通过在每一步选择局部最优解来获得全局最优解。

      def knapsack(weights, values, capacity):
          dp = [0] * (capacity + 1)
          for i in range(len(weights)):
              for w in range(capacity, weights[i] - 1, -1):
                  dp[w] = max(dp[w], dp[w - weights[i]] + values[i])
          return dp[capacity]
      

      7. 总结

      7.1 数据结构与算法实现的综合比较

      在实现数据结构与算法时,选择合适的结构和算法是至关重要的。顺序表适用于小规模数据的快速访问,而链表则更适合频繁的插入和删除操作。栈和队列在算法设计中广泛使用,而树和图则用于更复杂的数据关系。通过选择最适合的结构和算法,程序的性能可以得到显著提升。

      7.2 优化代码的常见方法与技巧

      在实现和优化代码时,应注意以下几点:

      • 代码重用:尽量使用模块化的设计,提高代码的可复用性。
      • 减少冗余:避免重复计算和无效操作,提升执行效率。
      • 内存管理:通过合理使用数据结构来优化内存使用,避免内存泄漏。
      • 测试和调优:通过单元测试和性能测试找出代码中的瓶颈,并进行针对性的优化。

      通过以上方法,开发者可以有效地实现和优化数据结构与算法,从而构建高效、稳定的应用程序。

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://weidonglang.blog.csdn.net/article/details/141310290,作者:小魏冬琅,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:数据结构与算法概述(1/6)

      下一篇:数据结构与算法的实现与优化

      相关文章

      2025-05-19 09:04:14

      《剑指Offer》搜索算法题篇——更易理解的思路~

      《剑指Offer》搜索算法题篇——更易理解的思路~

      2025-05-19 09:04:14
      算法
      2025-05-19 09:04:14

      复杂度的OJ练习

      复杂度的OJ练习

      2025-05-19 09:04:14
      代码 , 复杂度 , 思路 , 数组 , 算法
      2025-05-19 09:04:14

      《剑指Offer》按之字形顺序打印二叉树——最容易理解的思路,两分钟学会~

      《剑指Offer》按之字形顺序打印二叉树——最容易理解的思路,两分钟学会~

      2025-05-19 09:04:14
      二叉树 , 数据结构
      2025-05-19 09:04:14

      《剑指Offer》二叉搜索树的第k个节点——真没你想象中那么难,一招教你秒杀它~

      《剑指Offer》二叉搜索树的第k个节点——真没你想象中那么难,一招教你秒杀它~

      2025-05-19 09:04:14
      二叉树 , 数据结构
      2025-05-19 09:04:14

      【牛客网+LeetCode】链表 OJ强训题——高效解法

      【牛客网+LeetCode】链表 OJ强训题——高效解法

      2025-05-19 09:04:14
      数据结构 , 链表
      2025-05-19 09:04:14

      背包问题——“0-1背包”,“完全背包”(这样讲,还能不会?)

      背包问题——“0-1背包”,“完全背包”(这样讲,还能不会?)

      2025-05-19 09:04:14
      动态规划 , 算法
      2025-05-16 09:15:17

      多源BFS问题(2)_飞地的数量

      多源BFS问题(2)_飞地的数量

      2025-05-16 09:15:17
      bfs , grid , 单元格 , 算法
      2025-05-16 09:15:17

      BFS解决最短路问题(4)_为高尔夫比赛砍树

      BFS解决最短路问题(4)_为高尔夫比赛砍树

      2025-05-16 09:15:17
      BFS , lt , 复杂度 , 算法
      2025-05-16 09:15:17

      递归,搜索,回溯算法(3)之穷举,暴搜,深搜,回溯,剪枝

      递归,搜索,回溯算法(3)之穷举,暴搜,深搜,回溯,剪枝

      2025-05-16 09:15:17
      回溯 , 子集 , 数组 , 算法 , 递归
      2025-05-16 09:15:17

      多源BFS问题(4)_地图分析

      多源BFS问题(4)_地图分析

      2025-05-16 09:15:17
      单元格 , 算法 , 网格 , 距离
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5248621

      查看更多

      最新文章

      《剑指Offer》按之字形顺序打印二叉树——最容易理解的思路,两分钟学会~

      2025-05-19 09:04:14

      《剑指Offer》二叉搜索树的第k个节点——真没你想象中那么难,一招教你秒杀它~

      2025-05-19 09:04:14

      【牛客网+LeetCode】链表 OJ强训题——高效解法

      2025-05-19 09:04:14

      【数据结构】第一章——绪论(2)

      2025-05-14 10:33:31

      java实现3. 无重复字符的最长子串

      2025-05-13 09:50:17

      DS初阶:顺序表的实现

      2025-05-07 09:10:01

      查看更多

      热门文章

      Pandas之:深入理解Pandas的数据结构

      2023-03-22 09:34:26

      数据结构与算法之四 搜索算法

      2022-11-17 12:37:20

      数据结构入门(第一天)

      2023-02-24 09:05:57

      数据结构算法 简单的面试思考题

      2023-04-25 10:20:57

      Pandas数据结构

      2023-05-29 10:43:59

      数据结构这进制转换

      2023-05-31 08:43:33

      查看更多

      热门标签

      数据库 mysql 字符串 数据结构 MySQL 算法 redis oracle java sql python 数据 索引 SQL 查询
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      考研数据结构之树(6.5)——树与二叉树的应用之赫夫曼树和赫夫曼编码(C表示)

      堆应用:堆排序

      数据结构38-链表insert方法实现

      454. 四数相加 II

      【字典树 马拉车算法】336. 回文对

      考研数据结构之串(4.1)——串的操作(C表示)

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号