爆款云主机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云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      数据结构之AVL树

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

      数据结构之AVL树

      2025-02-11 09:38:28 阅读次数:25

      AVL,cur,parent,二叉,因子,平衡,搜索

      二叉搜索树的学习 我们在这篇文章中学习了二叉搜索树,知道了当插入的元素序列趋于有序时,将会导致 其效率变得十分底下。

      数据结构之AVL树

      今天,我们就来学习AVL树。

      目录

      AVL树的相关概念 

      AVL树的相关操作

      AVL树的插入

      右旋

      左旋 

      左右双旋 

      右左双旋 

      证明一棵二叉树是AVL树

      AVL树的性能分析


       

      AVL树的相关概念 

      二叉搜索树虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树,查找元素相当于在顺序表中搜索元素,效率低下。因此,两位俄罗斯的数学家G.M.Adelson-Velskii和E.M.Landis在1962年 发明了一种解决上述问题的方法:当向二叉搜索树中插入新结点后,如果能保证每个结点的左右子树高度之差的绝对值不超过 1(需要对树中的结点进行调整),即可降低树的高度,从而减少平均搜索长度。

      一棵AVL树要么是空树,要么是具有以下性质的二叉搜索树: 它的左右子树都是AVL树 左右子树高度之差(简称平衡因子)的绝对值不超过1(-1/0/1)。如下图所示:

      数据结构之AVL树

      如果一棵二叉搜索树是高度平衡的,它就是AVL树。如果它有n个结点,其高度可保持在 log n,搜索时间复杂度O(log n)。 因此AVL树也叫平衡的二叉搜索树。

      平衡因子的概念:一棵AVL树的右子树高度 减去 左子树的高度之差的结果。

      AVL树的相关操作

      首先,得定义一个树节点:

          class TreeNode {
              public int val;
              // 根结点的右子树高度-左子树的高度
              public int balanceFactor; // 平衡因子
              public TreeNode parent; // 父亲
              public TreeNode left; // 左子树
              public TreeNode right; // 右子树
      
              public TreeNode(int val) {
                  this.val = val;
              }
          }
      public TreeNode root;

      注意:

      1、这里采用的是孩子双亲表示法;

      2、一个新插入的节点,其平衡因子默认是0(因为其左子树和右子树皆为null,高度之差为0)。

      AVL树的插入

      思路:首先,得和二叉搜索树一样,找到合适的位置插入节点。

      代码实现:

          public boolean insert(int val) {
              // 如果root为null,就直接插入元素即可
              if (root == null) {
                  root = new TreeNode(val);
                  return true;
              }
              // 开始寻找要插入的元素位置
              TreeNode cur = root;
              TreeNode parent = null;
              while (cur != null) {
                  parent = cur;
                  if (cur.val < val) {
                      cur = cur.right;
                  } else if (cur.val > val) {
                      cur = cur.left;
                  } else {
                      return false; // 不能插入两个相同的元素
                  }
              }
              // 插入元素
              TreeNode node = new TreeNode(val);
              if (parent.val > val) {
                  parent.left = node;
              } else {
                  parent.right = node;
              }
              node.parent = parent;

      当插入成功之后,就得开始检查整棵树的平衡因子是否符合要求。但是整棵树的平衡因子都得检查一遍吗?不是的,我们在哪里插入的节点,就从该位置开始向上调整来修改平衡因子。如果平衡因子修改后符合我们的要求,则继续往上调整,直至parent为null即可,如果不符合要求,就得开始处理这种情况。处理完成之后肯定是符合我们的要求的,因此便可以不再进行检查了。

      思路:从插入节点的位置开始向上调整:看插入节点的位置是处于其parent的哪边:如果是右边,就让平衡因子++,如果是左边就让平衡因子--。接着再进行判断:如果parent的平衡因子的绝对值大于1的话,就得进行调整;如果等于1的话,就继续往上判断;如果等于0的话,就说明已经平衡了,不需要再进行判断了。

      代码实现: 

              // 判断是否是满足AVL树的条件:高度平衡(检查平衡因子)
              cur = node;
              while (parent != null) {
                  if (parent.left == cur) {
                      // 左树--
                      parent.balanceFactor--;
                  } else {
                      // 右树++
                      parent.balanceFactor++;
                  }
      
                  // 检查平衡因子的值
                  if (parent.balanceFactor == 0) {
                      // 说明已经平衡了
                      break;
                  } else if (parent.balanceFactor == 1 || parent.balanceFactor == -1) {
                      // 还得继续判断
                      cur = parent;
                      parent = cur.parent;
                  } else {
                      // 走到这里就说明平衡因子为2或者-2,是要进行修改的
                      if (parent.balanceFactor == 2) { // 右树高-->降低右树的高度
                          if (cur.balanceFactor == 1) {
                              // 左旋
                              rotateLeft(parent);
                          } else {
                              // 先右旋,再左旋(右左双旋)
                              ratateRL(parent);
                          }
                      } else { // 左树高-->降低左树的高度
                          if (cur.balanceFactor == 1) {
                              // 先左旋,再右旋(左右双旋)
                              ratateLR(parent);
                          } else {
                              // 右旋
                              rotateRight(parent);
                          }
                      }
                      // 调整完就说明已经是平衡的状态了,可以不用继续进行调整了
                      break;
                  }
              }
              return true;

      注意:

      1、平衡因子是右子树的高度减去左子树的高度之差。因此,插入的节点位置为parent的右子树时,parent的平衡因子就得++;反之,就得--。

      2、旋转的条件判断:

      右旋

      1、右旋的条件:全部是左树高(parent的左树高,cur的左树高),因此往右旋,以降低左树的高度,来达到平衡。

      数据结构之AVL树

      这里之所以把 cur.right 放到 parent 的左边,是因为 cur.right 肯定小于parent,且其位置被parent占有,因此只能往这里放。

      代码实现:

          private void rotateRight(TreeNode parent) {
              TreeNode subL = parent.left;
              TreeNode subLR = subL.right;
      
              TreeNode parentP = parent.parent;
      
              // 修改四个指针的指向
              parent.parent = subL;
              parent.left = subLR;
              // 判断是否为null
              if (subLR != null) {
                  subLR.parent = parent;
              }
              subL.right = parent;
      
              // 修改高树的指向和本级新的根结点指向
              if (parent == root) {
                  root = subL;
                  subL.parent = null;
              } else {
                  subL.parent = parentP; // 先得保存下来
                  if (parentP.left == parent) {
                      parentP.left = subL;
                  } else {
                      parentP.right = subL;
                  }
              }
              // 修改平衡因子
              subL.balanceFactor = 0;
              parent.balanceFactor = 0;
          }

      左旋 

      2、左旋的条件:全部是右树高(parent的右树高,cur的右树高),因此往左旋,以降低右树的高度,来达到平衡。 

      数据结构之AVL树

      代码实现:

          private void rotateRight(TreeNode parent) {
              TreeNode subL = parent.left;
              TreeNode subLR = subL.right;
      
              TreeNode parentP = parent.parent;
      
              // 修改四个指针的指向
              parent.parent = subL;
              parent.left = subLR;
              // 判断是否为null
              if (subLR != null) {
                  subLR.parent = parent;
              }
              subL.right = parent;
      
              // 修改高树的指向和本级新的根结点指向
              if (parent == root) {
                  root = subL;
                  subL.parent = null;
              } else {
                  subL.parent = parentP; // 先得保存下来
                  if (parentP.left == parent) {
                      parentP.left = subL;
                  } else {
                      parentP.right = subL;
                  }
              }
              // 修改平衡因子
              subL.balanceFactor = 0;
              parent.balanceFactor = 0;
          }

      左右双旋 

      3、左右双旋的条件:先左旋,再右旋(parent的左树高,cur的右树高) :先左旋cur,再右旋parent,降低左树高度,再降低右树高度,达到平衡。

      数据结构之AVL树

      上面分别是 cur.right无子树、有左子树无右子树、有右子树无左子树的三种情况,情况不同对应的平衡因子处理的方式就不相同。 并且当cur.right 处于无子树的时候,经过左旋和右旋代码的处理,平衡因子已经处于一种正常的状态。

      代码实现:

          private void ratateLR(TreeNode parent) {
              TreeNode subL = parent.left;
              TreeNode subLR = subL.right;
              // 通过subLR的平衡因子来判断节点的位置,从而确定调整后的平衡因子
              int bf = subLR.balanceFactor;
              // 先左旋parent的孩子节点
              rotateLeft(parent.left);
              // 再右旋parent节点
              rotateRight(parent);
              // 调整平衡因子、
              // 前面的旋转调整只满足一种情况:
              // 即平衡因子全为0的情况
              if(bf == -1) {
                  subL.balanceFactor = 0;
                  subLR.balanceFactor = 0;
                  parent.balanceFactor = 1;
              }else if (bf == 1){
                  subL.balanceFactor = -1;
                  subLR.balanceFactor = 0;
                  parent.balanceFactor = 0;
              }
          }

      右左双旋 

      4、右左双旋的条件: 先右旋,再左旋(parent的右树高,cur的左树高):先右旋cur,再左旋parent,降低右树的高度,再降低左树的高度,达到平衡。

      数据结构之AVL树

      上面分别是 cur.left无子树、有左子树无右子树、有右子树无左子树的三种情况,情况不同对应的平衡因子处理的方式就不相同。 并且当cur.left 处于无子树的时候,经过左旋和右旋代码的处理,平衡因子已经处于一种正常的状态。 

      代码实现:

          private void ratateRL(TreeNode parent) {
              TreeNode subR = parent.right;
              TreeNode subRL= subR.left;
              // 通过subRL的平衡因子来判断节点的位置,从而确定调整后的平衡因子
              int bf = subRL.balanceFactor;
              // 先右旋parent的孩子节点
              rotateRight(parent.right);
              // 再左旋parent节点
              rotateLeft(parent);
              // 调整平衡因子、
              // 前面的旋转调整只满足一种情况:
              // 即平衡因子全为0的情况
              if(bf == 1) {
                  parent.balanceFactor = -1;
                  subR.balanceFactor = 0;
                  subRL.balanceFactor = 0;
              }else if(bf == -1) {
                  parent.balanceFactor = 0;
                  subR.balanceFactor = 1;
                  subRL.balanceFactor = 0;
              }
          }

      通过上面的代码,一棵AVL树就被构建出来了。但是还得去证明这棵树是正确的AVL树。因为AVL树是一棵高度平衡的二叉搜索树,所以我们只要能同时证明是二叉搜索树,并且是一棵二叉平衡树即可。

      证明一棵二叉树是AVL树

      1、证明是一棵二叉搜索树:

      思路:只需要中序遍历这棵树即可。如果中序遍历的结果是有序的,那么就是一棵二叉搜索树。

      代码实现:

          public void inorder(TreeNode root) {
              if (root == null) {
                  return;
              }
              inorder(root.left);
              System.out.print(root.val+" ");
              inorder(root.right);
          }

      2、证明是一棵二叉平衡树:

      思路:只要证明每棵树都是二叉平衡树 && 计算出来的平衡因子和每个节点对应的平衡因子相同即可。 证明每棵树都是二叉平衡树,就是先证明根结点是,再去递归证明左子树和右子树。在这里免不了去求树的高度。

      代码实现:

          public boolean isBalanceTree(TreeNode root) {
              if (root == null) {
                  return true;
              }
              // 判断根结点是不是一棵二叉平衡树 + 其左右子树是不是一棵二叉平衡树
              // 二叉平衡树:左右子树的高度差 <= 1
              int leftHigh = TreeHigh(root.left);
              int rightHigh = TreeHigh(root.right);
      
              // 检查平衡因子
              if(rightHigh - leftHigh != root.balanceFactor) {
                  System.out.println(root.val+" 平衡因子异常!");
                  //return false;  // 可有可无
              }
      
      
              if (Math.abs(rightHigh-leftHigh) > 1) {
                  return false;
              }
              // 再判断左右子树是不是二叉平衡树
              return isBalanceTree(root.left) && isBalanceTree(root.right);
          }
      
          // 求树的高度:根节点(1)+Math.max(左子树,右子树)
          private int TreeHigh(TreeNode root) {
              if (root == null) {
                  return 0;
              }
              if (root.left == null && root.right == null) {
                  return 1;
              }
              return 1 + Math.max(TreeHigh(root.left), TreeHigh(root.right));
          }

      验证代码写出来之后,就可以开始去测试了。 

      思路:就是看是否同时满足上面两个条件即可。

      代码实现:

      public class Test {
          public static void main(String[] args) {
              AVLTree avlTree = new AVLTree();
      
              int[] array = {16, 3, 7, 11, 9, 26, 18, 14, 15}; // 常见场景
              //int[] array = {4, 2, 6, 1, 3, 5, 15, 7, 16, 14}; // 特殊场景
      
              // 插入元素
              for (int i = 0; i < array.length; i++) {
                  avlTree.insert(array[i]);
              }
              // 中序遍历
              avlTree.inorder(avlTree.root);
              System.out.println();
              // 判断是否为二叉平衡树
              System.out.println(avlTree.isBalanceTree(avlTree.root));
          }
      }
      

       AVL树的删除步骤:

      1、找到要删除的节点

      2、和删除二叉搜索树一样,分为四种情况(具体可见上面的链接)

      3、删除成功之后,就得要更新平衡因子(左树降低,平衡因子就++;反之,则--)。

      注意:删除之后的调整是向上调整,可能会调整到根节点。

      AVL树的性能分析

      AVL树是一棵绝对平衡的二叉搜索树,其要求每个节点的左右子树高度差的绝对值都不超过1,这样可以保证查询时高效的时间复杂度,即log N。

      但是如果要对AVL树做一些结构修改的操作,性能非常低下,比如:插入时要维护其绝对平衡,旋转的次数比较多,更差的是在删除时,有可能一直要让旋转持续到根的位置。

      因此:如果需要一种查询高效且有序的数据结构,而且数据的个数为静态的(即不会改变),可以考虑AVL树,但一个结构经常修改,就不太适合。因此就有了红黑树,我们下一期再学习。

      好啦!本期 数据结构之AVL树 的学习之旅就到此结束啦!我们下一期再一起学习吧!

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

      上一篇:数据结构之顺序表的相关知识点及应用

      下一篇:scanf与printf函数的详细介绍及其用法

      相关文章

      2025-05-14 10:03:13

      【MySQL】-数据库优化(索引)

      索引(index)是帮助数据库高效获取数据的数据结构

      2025-05-14 10:03:13
      index , Tree , 二叉 , 搜索 , 数据 , 索引 , 节点
      2025-05-14 09:51:15

      java实现管线拓扑关系连通性分析

      管线拓扑关系的连通性分析通常涉及图论(Graph Theory)中的概念,特别是无向图(Undirected Graph)的遍历算法,如深度优先搜索(DFS, Depth-First Search)或广度优先搜索(BFS, Breadth-First Search)。

      2025-05-14 09:51:15
      BFS , DFS , 复杂度 , 搜索 , 节点 , 访问 , 遍历
      2025-05-13 09:50:28

      将有序数组转换为二叉搜索树,98. 验证二叉搜索树

      将有序数组转换为二叉搜索树给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 平衡 二叉搜索树。 

      2025-05-13 09:50:28
      nums , 二叉 , 右子 , 左子 , 搜索 , 节点
      2025-05-13 09:50:17

      二叉搜索树中第K小的元素

      给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找其中第 k 个最小元素(从 1 开始计数)。 

      2025-05-13 09:50:17
      Node , root , val , 二叉 , 节点
      2025-05-13 09:49:12

      用go语言,现有一棵无向、无根的树,树中有 n 个节点,按从 0 到 n - 1 编号 给你一个整数 n 和一个长度为 n - 1 的二维整数数组 edges

      用go语言,现有一棵无向、无根的树,树中有 n 个节点,按从 0 到 n - 1 编号 给你一个整数 n 和一个长度为 n - 1 的二维整数数组 edges

      2025-05-13 09:49:12
      cur , 数组 , 查询 , 节点 , 遍历
      2025-05-12 10:19:12

      DS进阶:AVL树和红黑树

      二叉搜索树(BST)虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树,查找元素相当于在顺序表中搜索元素,效率低下。

      2025-05-12 10:19:12
      AVL , 平衡 , 插入 , 旋转 , 红黑树 , 结点 , 节点
      2025-05-12 08:45:17

      不同的二叉搜索树 II

      给你一个整数 n ,请你生成并返回所有由 n 个节点组成且节点值从 1 到 n 互不相同的不同 二叉搜索树 。可以按 任意顺序 返回答案。

      2025-05-12 08:45:17
      lt , 二叉 , 搜索 , 示例 , 节点
      2025-05-12 08:45:17

      恢复二叉搜索树

      给你二叉搜索树的根节点 root ,该树中的 恰好 两个节点的值被错误地交换。请在不改变其结构的情况下,恢复这棵树 。 

      2025-05-12 08:45:17
      lt , 二叉 , 示例 , 节点
      2025-05-12 08:43:47

      验证二叉搜索树

      给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

      2025-05-12 08:43:47
      二叉 , 搜索 , 示例 , 节点
      2025-05-09 09:30:19

      将有序数组转换为二叉搜索树

       nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。

      2025-05-09 09:30:19
      二叉 , 二叉树 , 数组 , 示例 , 高度
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5246467

      查看更多

      最新文章

      【MySQL】-数据库优化(索引)

      2025-05-14 10:03:13

      【数据结构】二叉搜索树

      2025-04-22 09:27:37

      【数据结构】AVL树(平衡二叉搜索树)

      2025-04-22 09:27:37

      【深度优先搜索】【树】【状态压缩】2791. 树中可以形成回文的路径数

      2025-03-25 08:07:53

      【贪心】【回溯】【字符串】2014. 重复 K 次的最长子序列|2558

      2025-03-25 08:07:53

      全网最详细之pt-osc 处理MySQL外键表流程分析

      2025-03-17 08:27:30

      查看更多

      热门文章

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

      2022-11-17 12:37:20

      数据结构-用二维数组构造列表

      2023-02-15 08:39:14

      每日学习一个数据结构-AVL树

      2024-12-13 06:53:39

      150道MySQL高频面试题,学完吊打面试官--平衡二叉树,红黑树,B树和B+树

      2024-12-19 09:33:37

      数据结构之红黑树

      2025-02-12 09:28:06

      数据结构:二叉搜索树

      2024-11-01 09:15:10

      查看更多

      热门标签

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

      相关产品

      弹性云主机

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

      天翼云电脑(公众版)

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

      对象存储

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

      云硬盘

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

      查看更多

      随机文章

      vue-组件通信(二)

      数据结构-用二维数组构造列表

      【MySQL】-数据库优化(索引)

      【深度优先搜索】【树】【状态压缩】2791. 树中可以形成回文的路径数

      【数据结构】二叉搜索树

      数据结构:二叉搜索树

      • 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号