活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 一键部署Llama3大模型学习机 0代码一键部署,预装最新主流大模型Llama3与StableDiffusion
  • 中小企业应用上云专场 产品组合下单即享折上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云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      C语言:函数递归

      首页 知识中心 软件开发 文章详情页

      C语言:函数递归

      2025-05-07 09:12:52 阅读次数:1

      个数,函数,迭代,递归

      一、什么是递归

      递归式一种解决问题的方法,在C语言中,递归就是自己调用自己。

      递归的思想: 把⼀个⼤型复杂问题层层转化为⼀个与原问题相似,但规模较小的⼦问题来求解;直到⼦问题不能再被拆分,递归就结束了。所以递归的思考⽅式就是把⼤事化小的过程。

      递归中的递就是递推的意思,归就是回归的意思

      int main()
      {
       printf("hehe\n");
       main();//main函数中⼜调⽤了main函数
       return 0;
      }

      以上就是一个简答的递归程序(自己调用自己),但是最后代码会陷入死递归,导致栈溢出(stack overflow)

      所以递归必须要有自己的限制条件!而不能无限制地递归

      二、递归的限制条件

      为了防止死递归,有2个必要条件:

      1、递归存在限制条件,当满足这个条件的时候,递归便不再继续(也就是说,我们要设置让递归停止下来的条件)

      2、每次递归的调用要越来越接近这个限制条件(要慢慢让递归停下来)

      三、递归的举例

      3.1 求n的阶乘

      我们知道n的阶乘的公式: n! =  n ∗ (n − 1)!

      这样的思路就是把⼀个较⼤的问题,转换为⼀个与原问题相似,但规模较⼩的问题来求解的。

      n!---> n*(n-1)! (n-1)! ---> (n-1)*(n-2)!.... 直到n是1或者0时,不再拆解

      再稍微分析⼀下,当 n<=1 的时候,n的阶乘是1,其余n的阶乘都是可以通过上述公式计算。

      n的阶乘的递归公式如下:

      C语言:函数递归

      Fact(int n)
      {
      	if (n <= 0)
      		return 1;
      	else
      		return n * Fact(n - 1);
      }
      int main()
      {
      	int n = 0;
      	scanf("%d", &n);
      	int ret=Fact(n);
      	printf("%d", ret);
      	return 0;
      }

      3.2 按顺序打印一个整数的每一位

              1234%10就能得到4,然后1234/10得到123,这就相当于去掉了4 然后继续对123%10,就得到了3,再除10去掉3,以此类推 不断的 %10 和 \10 操作,直到1234的每⼀位都得到; 但是这⾥有个问题就是得到的数字顺序是倒着的,我们以这个思路设想一个Print函数

      Print(n)
      如果n是1234,那表⽰为
      Print(1234) //打印1234的每⼀位
      其中1234中的4可以通过%10得到,那么
      Print(1234)就可以拆分为两步:
      1. Print(1234/10) //打印123的每⼀位
      2. printf(1234%10) //打印4
      完成上述2步,那就完成了1234每⼀位的打印
      那么Print(123)⼜可以拆分为Print(123/10) + printf(123%10)

      直到被打印的数字变成⼀位数的时候,就不需要再拆分,递归结束。

      C语言:函数递归

      void Print(int n)
      {
       if(n>9)
       {
       Print(n/10);
       }
       printf("%d ", n%10);
      }
      int main()
      {
       int m = 0;
       scanf("%d", &m);
       Print(m);
       return 0;
      }
      

       

      3.3 斐波那契数列

      第1个数和第2个数是1,从第3个数开始,后面每个数都是前两个数之和,所以当n大于2时,有Fib(n)=Fib(n-1)+Fib(n-2)

      int Fib(int n)
      {
       if(n<=2)
       return 1;
       else
       return Fib(n-1)+Fib(n-2);
      }
      int main()
      {
       int n = 0;
       scanf("%d", &n);
      int ret = Fib(n);
       printf("%d\n", ret); 
       return 0;
      }

      四、迭代

      迭代,通常就是循环的方式

      4.1 求n的阶乘

      Fact(int n)
      {
      	int ret = 1;
      	for (int i = 1; i <= n; i++)
      		ret *= i;
      	return ret;
      }
      int main()
      {
      	int n = 0;
      		scanf("%d", &n);
      		int ret=Fact(n);
      		printf("%d", ret);
      		return 0;
      }

      4.2 斐波那契数列

      Fib(int n)
      {
      	int a = 1;
      	int b = 1;
      	int c = 1;
      	while (n >= 3)
      	{
      		c = a + b;
      		a = b;
      		b = c;
      		n--;
      	}
      	return c;
      }
      int main()
      {
      	int n = 0;
      		scanf("%d", &n);
      		int ret=Fib(n);
      		printf("%d", ret);
      		return 0;
      }

      五、递归与迭代的选择

             递归函数在有些时候是可以产生争取的结果,并且往往几行代码就可以完成大量的运算,但是在递归函数调用的过程中也会存在一些运行的开销。

             在C语⾔中每⼀次函数调⽤,都要需要为本次函数调⽤在栈区申请⼀块内存空间来保存函数调⽤期间 的各种局部变量的值,这块空间被称为运⾏时堆栈,或者函数栈帧。

             函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归 函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。

           所以如果采⽤函数递归的⽅式完成代码,递归层次太深,就会浪费太多的栈帧空间,也可能引起栈溢出(stack overflow)的问题。

           事实上,我们看到的许多问题是以递归的形式进⾏解释的,这只是因为它⽐⾮递归的形式更加清晰, 但是这些问题的迭代实现往往⽐递归实现效率更⾼。

            比如斐波那契数列,当我们使用递归的方法就解决时,如果输入50,需要很长的时间才能算出结果,因为递归程序会不断展开,在展开的过程中会有很多次的重复计算,而且递归层次越深,冗余计算就会越来越多。

      #include <stdio.h>
      int count = 0;
      int Fib(int n)
      {
       if(n == 3)
       count++;//统计第3个斐波那契数被计算的次数
       if(n<=2)
       return 1;
       else
       return Fib(n-1)+Fib(n-2);
      }
      int main()
      {
       int n = 0;
       scanf("%d", &n);
       int ret = Fib(n);
       printf("%d\n", ret); 
       printf("\ncount = %d\n", count);
       return 0;
      }

       输入40   输出39088169    

            在计算第40个斐波那契数的时候,使⽤递归⽅式,第3个斐波那契数就被重复计算了 39088169次,这些计算是⾮常冗余的。所以斐波那契数的计算,使⽤递归是⾮常不明智的,所以迭代的效率会更优!!

           而当⼀个问题⾮常复杂,难以使⽤迭代的⽅式实现时,此时递归实现的简洁性便可以补偿它所带来的运⾏时开销。

          有时候,递归虽好,但是也会引入⼀些问题,所以我们⼀定不要迷恋递归,适可而止就好。

      六、递归拓展问题

      6.1 青蛙跳台阶问题

      一个青蛙,一次只能跳一个台阶或者两个台阶,求跳n个台阶有几种跳法??

      分析:

      n=1,跳1次一个台阶,即jump(1)=1

      n=2,可以跳2次一个台阶,也可以直接跳两个太极,即jump(2)=2

      n=3,可以跳3次一个台阶,或者先跳1个台阶再跳2个台阶,或者先跳2个台阶再跳1个台阶,即jump(3)=3

      n=4,可以 1111  22 2111 1211 1121 1112 即jump(4)=6

      ……

      我们发现,当jump(3)时,如果第一次跳了1个台阶,剩下2个台阶的跳法相当于jump(2),如果第一个跳了2个台阶,剩下1个台阶的跳法相当于jump(1)

      所以我们可以得到jump(3)=jump(1)+jump(2)

      即jump(n)=jump(n-1)+jump(n-2)

      递归:

      jump(int n)
      {
          assert(N>=0);
      	if (n <= 2)
      		return n;
      	else
      		return jump(n - 1) + jump(n - 2);
      }
      int main()
      {
      	int n = 0;
      		scanf("%d", &n);
      		int ret=jump(n);
      		printf("%d", ret);
      		return 0;
      }
      

      迭代:

      jump(int n)
      {
          assert(n>=0);
      	int a = 1;
      	int b = 2;
      	int c = 0;
      	if (n <= 2)
      		return n;
      	else
      	{
      		for (int i = 3; i <= n; i++)
      		{
      			c = a + b;
      			a = b;
      			b = c;
      		}
      		return c;
      	}
      }
      int main()
      {
      	int n = 0;
      	scanf("%d", &n);
      	int ret = jump(n);
      	printf("%d", ret);
      	return 0;
      }

      6.2 汉诺塔问题

      C语言:函数递归

            简单的理解就是有三根柱子,其中一根柱子上有n个由上到下逐渐增大的圆盘,我们需要在保证圆盘始终是大圆盘在下,小圆盘在上的情况下每次移动一个圆盘,直到完成所有圆盘的移动。如图所示,要探究将n个圆盘从A挪动到C挪动的过程,以及挪动顺序

      分析:

      1个圆盘:A->C                   共1次

      2个圆盘:A->B

                      A->C

                       B->C                   共3次

      3个圆盘    A->C

                       A->B

                       C->B

                       A->C

                       B->A

                       B->C

                       A->C                       共7次

      我们发现,最中间的次数恰好就是A->C即最大的圆盘移到C上,中间次数之前相当于将最大圆盘之上的n-1个圆盘放到辅助柱子B上,而中间次数之和的次数相当于将辅助B之上的n-1个圆盘放回C上,所以我们可以得到公式挪动次数:F(n)=F(n-1)+1+F(n-1)即F(n)=F(n-1)*2+1

      F(int n)
      {
      	assert(n>=0);
      	if (n==0)
      		return 0;
      	else
      		return 2*F(n - 1)+1;
      }

      而挪动的过程我们封装2个函数

      void Move(char a, char b, int n)
      {
      	//n代表第几个圆盘,a和b穿得是柱子的编号,表示从a柱子挪到b柱子
      	printf("第%d个圆盘从%c柱挪动到%c柱\n", n, a, b);
      }
      void Hanoi(char a, char b, char c, int n)
      //a表示圆盘所在的柱子,b表示移动圆盘的辅助柱子,c表示圆盘的目标柱子,n表示圆盘的个数
      {
      	assert(n >= 0);
      	if (n ==1)
      		Move(a, c, n);//直接将圆盘放到c上
      	else
      	{
      		Hanoi(a, c, b, n - 1);//将前面n-1个圆盘通过C先挪动到B上
      		Move(a, c, n);//将第n个圆盘放到c上
      		Hanoi(b, a, c, n - 1);//将b上的n-1个圆盘通过a挪动到c上
      	}
      }

      最后通过这三个函数完成计算汉诺塔问题的挪动次数以及挪动的过程!!

      F(int n)//计算挪动次数
      {
      	assert(n>=0);
      	if (n==0)
      		return 0;
      	else
      		return 2*F(n - 1)+1;
      }
      void Move(char a, char b, int n)
      {
      	//n代表第几个圆盘,a和b穿得是柱子的编号,表示从a柱子挪到b柱子
      	printf("第%d个圆盘从%c柱挪动到%c柱\n", n, a, b);
      }
      void Hanoi(char a, char b, char c, int n)
      //a表示圆盘所在的柱子,b表示移动圆盘的辅助柱子,c表示圆盘的目标柱子,n表示圆盘的个数
      {
      	assert(n > 0);
      	if (n == 1)
      		Move(a, c, n);//将圆盘直接移动到c上
      	else
      	{
      		Hanoi(a, c, b, n - 1);//将前面n-1个圆盘通过C先挪动到B上
      		Move(a, c, n);//将第n个圆盘放到c上
      		Hanoi(b, a, c, n - 1);//将b上的n-1个圆盘通过a挪动到c上
      	}
      }
      int main()
      {
      	int n = 0;
      	scanf("%d", &n);//输入圆盘数量
      	char src = 'A';//a代表圆盘所在的柱子
      	char ass = 'B';//b代表a->c的辅助柱子
      	char dst = 'C';//c代表圆盘的目标柱子
      	printf("挪动过程如下:\n");
      	Hanoi(src,ass,dst, n);//挪动过程
      	printf("挪动次数为%d次", F(n));//挪动次数
      	return 0;
      }

      C语言:函数递归 

      6.3 求1-n的全排列

            比如1、2、3、4、5,为了实现全排列,我们先将他放在一个数组中,我们先取第1个数,如果第1个数确定为2,那么第1个数是2的全排列就即为1345的全排列,第2个数可以取1345中的1个数,又可以等价于后三个数的全排列,以此类推……

      因此,n个数的全排列=确定的第一位+(n-1)个数全排列=确定的前两位+(n-2)个数全排列=............

      其中,确定某位是某数这一操作由——与后面的数依次交换-递归-换回——实现。

      int count = 0;//利用全局变量计算总次数
      void swap(int arr[], int a, int b)//交换下标为a  b的两个数
      {
      	int temp = arr[a];
      	arr[a] = arr[b];
      	arr[b] = temp;
      }
      void Perm(int arr[], int begin, int n)//n为最后一个数的角标,begin为数组从下标为几的数字开始
      {
      	assert(n > 0);
      	if (begin == n)
      	{	//如果begin为最后一个元素开始,说明该层递归已经结束了,此次数组的顺序就是全排列的顺序
      		for (int i = 0; i < n; i++)
      			printf("%d-", arr[i]);
      		printf("%d\n", arr[n]);
      		count++;//利用全局变量计算总次数
      	}
      	else//如果begin还在前面,就要将begin与后面的数一次交换然后递归,每次递归完要回溯
      	{
      		for (int k = begin; k <= n; k++)
      		{
      			//begin与后面的数依次交换
      			swap(arr, begin, k);
      			//问题变成begin与后面的数进行全排列
      			Perm(arr, begin + 1, n);
      			//回溯
      			swap(arr, begin, k);
      		}
      	}
      }
      int main()
      {
      	int* arr;
      	int n;
      	printf("请输入n:");
      	scanf("%d", &n);
      	arr = (int*)malloc(n*sizeof(int));
          //创建数组
      	for (int i = 0; i < n; i++)
      		arr[i] = i + 1;
      	Perm(arr, 0, n - 1);//开始进行全排列
      	printf("一共有%d种排列方式", count);
      }

      C语言:函数递归

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

      上一篇:C语言:自定义类型——联合和枚举

      相关文章

      2025-05-07 09:12:52

      C语言:预处理详解

      C语⾔设置了⼀些预定义符号,可以直接使⽤,预定义符号也是在预处理期间处理的。

      2025-05-07 09:12:52
      define , 函数 , 参数 , 头文件 , 定义 , 替换 , 编译
      2025-05-07 09:12:52

      C语言:内存函数

      C语言:内存函数

      2025-05-07 09:12:52
      memcpy , memmove , 内存 , 函数 , 字节 , 拷贝 , 重叠
      2025-05-07 09:10:01

      MySQL—函数—流程控制函数(基础)

      流程控制函数在我们 sql 语句当中,经常用来实现条件的筛选,从而提高语句的一个执行效率。

      2025-05-07 09:10:01
      value , 函数 , 返回 , 默认值
      2025-05-07 09:10:01

      C语言:动态内存管理

      C语言:动态内存管理

      2025-05-07 09:10:01
      内存 , 函数 , 指针 , 数组 , 空间 , 释放
      2025-05-07 09:10:01

      MySQL—函数—日期函数(基础)

      MySQL—函数—日期函数(基础)

      2025-05-07 09:10:01
      date , type , 函数 , 天数 , 当前 , 日期 , 时间
      2025-05-07 09:10:01

      MySQL—函数—数值函数(基础)

      MySQL—函数—数值函数(基础)

      2025-05-07 09:10:01
      函数 , 取整 , 数值 , 案例 , 演示 , 验证码
      2025-05-07 09:10:01

      DS初阶:顺序表的实现

      DS初阶:顺序表的实现

      2025-05-07 09:10:01
      函数 , 指针 , 数据 , 数据结构 , 数组 , 空间 , 顺序
      2025-05-07 09:08:23

      Qt中音频的使用

      于音频我们在使用的过程中一般是录制音频、播放音频。针对这两个需求介绍Qt中音频的使用。

      2025-05-07 09:08:23
      函数 , 对象
      2025-05-07 09:08:23

      C++语言---作用域和命名空间

      在全局作用域中,我们定义的函数或者是数据都是全局可见的,在整个项目中都可以调用和使用。一般的声明和定义都是在命名空间之外。一般全局变量需要定义在CPP文件中,如果定义在头文件中,那么在引入的时候会出现重复定义的问题。

      2025-05-07 09:08:23
      作用域 , 函数 , 命名 , 定义 , 空间
      2025-05-07 09:08:23

      Qt中线程的使用

      在qt中线程的使用有两种方式,第一种就是创建一个类继承QObject类,之后使用moveToThread函数将线程添加到类中。另一种就是创建一个类继承QThread类,在类中实现run函数。

      2025-05-07 09:08:23
      run , 使用 , 函数 , 线程
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      32986

      阅读量

      4919700

      查看更多

      最新文章

      C语言:预处理详解

      2025-05-07 09:12:52

      C语言:内存函数

      2025-05-07 09:12:52

      C语言:动态内存管理

      2025-05-07 09:10:01

      Qt中线程的使用

      2025-05-07 09:08:23

      C++语言---作用域和命名空间

      2025-05-07 09:08:23

      MFC如何防止应用软件启动多个窗口

      2025-05-07 09:08:16

      查看更多

      热门文章

      Python|斐波那契数列

      2023-02-27 10:01:21

      PHP:将list列表转为tree树形数据

      2023-02-28 08:23:26

      Python 函数调用父类详解

      2023-04-23 09:44:31

      Python编程:pkgutil获取包里面的所有模块列表

      2023-03-16 07:45:06

      游戏编程之六 游戏编程的特点

      2024-09-25 10:13:46

      C#8.0新语法

      2023-02-07 10:34:04

      查看更多

      热门标签

      java Java python 编程开发 开发语言 代码 算法 线程 html Python 数组 C++ javascript c++ 元素
      查看更多

      相关产品

      弹性云主机

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

      天翼云电脑(公众版)

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

      对象存储

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

      云硬盘

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

      查看更多

      随机文章

      C++——多态

      C语言内存函数

      Java中的函数式编程指南

      数据结构之栈详解(C语言手撕)

      C++接口类, 抽象类和实体类简述

      二级考试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号