ImageVerifierCode 换一换
格式:DOC , 页数:37 ,大小:51.50KB ,
资源ID:11234405      下载积分:12 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/11234405.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(经典数据结构面试题含答案.doc)为本站上传会员【丰****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

经典数据结构面试题含答案.doc

1、经典数据结构面试题含答案 资料仅供参考 栈和队列的共同特点是__________________________ .栈一般采用的两种存储结构是______________________ .用链表表示线性表的优点是_______________________ 8.在单链表中,增加头结点的目的是___________________ 9.循环链表的主要优点是________________________- 12.线性表的顺序存储结构和线性表的链式存储结构分别是__________________________ 13.树是结点的集合,它的根结点

2、数目是_____________________ 14.在深度为5的满二叉树中,叶子结点的个数为_______________ 15.具有3个结点的二叉树有(_____________________ 16.设一棵二叉树中有3个叶子结点,有8个度为1的结点,则该二叉树中总的结点数为____________________ 17.已知二叉树后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是____________________________ 18.已知一棵二叉树前序遍历和中序遍历分别为ABDEGCFH和DBGEACHF,则该二叉树的后序遍历为

3、 19.若某二叉树的前序遍历访问顺序是abdgcefh,中序遍历访问顺序是dgbaechf,则其后序遍历的结点访问顺序是_______________________ 20.数据库保护分为:安全性控制、 完整性控制 、并发性控制和数据的恢复。 在计算机中,算法是指_______________________ 算法一般都能够用哪几种控制结构组合而成_____________________ .算法的时间复杂度是指______________________ 5. 算法的空间复杂度是指___________

4、 6. 算法分析的目的是__________________________ 11. 数据的存储结构是指_________________________ 12. 数据的逻辑结构是指(_______________________________ 13. 根据数据结构中各数据元素之间前后件关系的复杂程度,一般将数据结构分为__________________________________ 16. 递归算法一般需要利用_______________________实现。 28. 非空的循环单链表head的尾结点(由p所指向),

5、满足(_____________________ 29.与单向链表相比,双向链表的优点之一是____________________________-- 34. 在一棵二叉树上第8层的结点数最多是____________ 35. 在深度为5的满二叉树中,叶子结点的个数为____________\ 36. 在深度为5的满二叉树中,共有________________个结点 37.设一棵完全二叉树共有699个结点,则在该二叉树中的叶子结点数为_________________ 说明:完全二叉树总结点数为N,若N为奇数,则叶子结点数为(N+1)/2;若N为偶数,则叶子结点

6、数为N/2。 39.已知二叉树后序遍历序列是dabec,中序遍历序列debac,它的前序遍历序列是(cedba) 40. 已知一棵二叉树前序遍历和中序遍历分别为ABDEGCFH和DBGEACHF,则该二叉树的后序遍历为(DGEBHFCA) 41.若某二叉树的前序遍历访问顺序是abdgcefh,中序遍历访问顺序是dgbaechf,则其后序遍历的结点访问顺序是(gdbehfca) 42. 串的长度是(串中所含字符的个数) 43.设有两个串p和q,求q在p中首次出现位置的运算称做(模式匹配) 44. N个顶点的连通图中边的条数至少为(N-1) 45.N个顶点的强

7、连通图的边数至少有(N) 46.对长度为n的线性表进行顺序查找,在最坏情况下所需要的比较次数为(N) 47. 最简单的交换排序方法是(冒泡排序) 48.假设线性表的长度为n,则在最坏情况下,冒泡排序需要的比较次数为(n(n-1)/2) 49. 在待排序的元素序列基本有序的前提下,效率最高的排序方法是(冒泡排序) 50. 在最坏情况下,下列顺序方法中时间复杂度最小的是(堆排序) 51. 希尔排序法属于(插入类排序) 52. 堆排序法属于(选择类排序) 53. 在下列几种排序方法中,要求内存量最大的是(归并排序) 54. 已知数据表A中

8、每个元素距其最终位置不远,为节省时间,应采用(直接插入排序) 55. 算法的基本特征是可行性、确定性、 有穷性   和拥有足够的情报。 一个算法一般由两种基本要素组成:一是对数据对象的运算和操作,二是算法的控制结构。 1. 算法的复杂度主要包括时间复杂度和 空间 复杂度。 2. 实现算法所需的存储单元多少和算法的工作量大小分别称为算法的空间复杂度和时间复杂度 。 3.所谓数据处理是指对数据集合中的各元素以各种方式进行运算,包括插入、删除、查找、更改等运算,也包括对数据元素进行分析。 4.数据结构是指相互有关联的 数据元素 的集合。 5.数据结构分为逻辑结构与存

9、储结构,线性链表属于 存储结构 。 6.数据结构包括数据的 逻辑 结构和数据的存储结构。 7. 数据结构包括数据的逻辑结构、数据的 存储结构 以及对数据的操作运算。 8.数据元素之间的任何关系都能够用 前趋和后继 关系来描述。 9.数据的逻辑结构有线性结构和非线性结构两大类。 10.常见的存储结构有顺序、链接、 索引 等存储结构。 11. 顺序存储方法是把逻辑上相邻的结点存储在物理位置   相邻 的存储单元中。 12. 栈的基本运算有三种:入栈、退栈与读栈顶元素 。 13. 队列主要有两种基本运算:入队运算与 退队运算 。 14. 在实际应

10、用中,带链的栈能够用来收集计算机存储空间中所有空闲的存储结点,这种带链的栈称为 可利用栈 。 15.栈和队列一般采用的存储结构是 链式存储和顺序存储   。 16.当线性表采用顺序存储结构实现存储时,其主要特点是 逻辑结构中相邻的结点在存储结构中仍相邻 。 17. 循环队列主要有两种基本运算:入队运算与退队运算。每进行一次入队运算,队尾指针就 进1 。 18.当循环队列非空且队尾指针等于对头指针时,说明循环队列已满,不能进行入队运算。这种情况称为 上溢   。 19.当循环队列为空时,不能进行退队运算,这种情况称为 下溢 。 20. 在一个容量为25的循环队

11、列中,若头指针front=16,尾指针rear=9,则该循环队列中共有 18 个元素。注:当rearfront时,元素个数=rear-front。 5.下列关于栈的叙述正确的是(D)      A.栈是非线性结构B.栈是一种树状结构C.栈具有先进先出的特征D.栈有后进先出的特征 6.链表不具有的特点是(B)A.不必事先估计存储空间       B.可随机访问任一元素 C.插入删除不需要移动元素      D.所需空间与线性表长度成正比 10.线性表L=(a1,a2,a3,……ai,……

12、an),下列说法正确的是(D)      A.每个元素都有一个直接前件和直接后件   B.线性表中至少要有一个元素      C.表中诸元素的排列顺序必须是由小到大或由大到小      D.除第一个和最后一个元素外,其余每个元素都有一个且只有一个直接前件和直接后件 11.线性表若采用链式存储结构时,要求内存中可用存储单元的地址(D) A.必须是连续的 B.部分地址必须是连续的C.一定是不连续的 D.连续不连续都能够 7. 下列叙述正确的是(C) A.算法的执行效率与数据的存储结构无关 B.算法的空间复杂度是指算法程序中指令(或语句)的条数 C.算法的有穷性是指算法

13、必须能在执行有限个步骤之后终止 D.算法的时间复杂度是指执行算法程序所需要的时间 8.数据结构作为计算机的一门学科,主要研究数据的逻辑结构、对各种数据结构进行的运算,以及(数据的存储结构) 9. 数据结构中,与所使用的计算机无关的是数据的(C) A.存储结构   B.物理结构     C.逻辑结构     D.物理和存储结构 10. 下列叙述中,错误的是(B) A.数据的存储结构与数据处理的效率密切相关 B.数据的存储结构与数据处理的效率无关 C.数据的存储结构在计算机中所占的空间不一定是连续的 D.一种数据的逻辑结构能够有多种存储结构 14. 下列数据结构具有记忆功能

14、的是(C)A.队列B.循环队列C.栈D.顺序表 15. 下列数据结构中,按先进后出原则组织数据的是(B) A.线性链表   B.栈            C.循环链表        D.顺序表 17. 下列关于栈的叙述中正确的是(D)A.在栈中只能插入数据B.在栈中只能删除数据 C.栈是先进先出的线性表            D.栈是先进后出的线性表 20. 由两个栈共享一个存储空间的好处是(节省存储空间,降低上溢发生的机率) 21. 应用程序在执行过程中,需要经过打印机输出数据时,一般先形成一个打印作业,将其存放在硬盘中的一个指定(队列)中,当打印机空闲时,就会按先来先服务

15、的方式从中取出待打印的作业进行打印。 22.下列关于队列的叙述中正确的是(C)A.在队列中只能插入数据 B.在队列中只能删除数据   C.队列是先进先出的线性表            D.队列是先进后出的线性表 23.下列叙述中,正确的是(D)A.线性链表中的各元素在存储空间中的位置必须是连续的 B.线性链表中的表头元素一定存储在其它元素的前面 C.线性链表中的各元素在存储空间中的位置不一定是连续的,但表头元素一定存储在其它元素的前面 D.线性链表中的各元素在存储空间中的位置不一定是连续的,且各元素的存储顺序也是任意的 24.下列叙述中正确的是(A)A.线性表是线性结构      B.

16、栈与队列是非线性结构 C.线性链表是非线性结构                                 D.二叉树是线性结构 25. 线性表L=(a1,a2,a3,……ai,……an),下列说法正确的是(D) A.每个元素都有一个直接前件和直接后件      B.线性表中至少要有一个元素 C.表中诸元素的排列顺序必须是由小到大或由大到小D.除第一个元素和最后一个元素外,其余每个元素都有一个且只有一个直接前件和直接后件 26.线性表若采用链式存储结构时,要求内存中可用存储单元的地址(连续不连续都能够) 27. 链表不具有的特点是(B)A.不必事先估计存储空间        

17、    B.可随机访问任一元素 C.插入删除不需要移动元素            D.所需空间与线性表长度成正比 30. 在(D)中,只要指出表中任何一个结点的位置,就能够从它出发依次访问到表中其它所有结点。A.线性单链表            B.双向链表            C.线性链表            D.循环链表 31. 以下数据结构属于非线性数据结构的是(C)A.队列      B.线性表C.二叉树      D.栈 38. 设有下列二叉树,对此二叉树中序遍历的结果是(B) A.ABCDEF      B.DBEAFC C.ABDECF     

18、D.DEBFCA 1.判断链表是否存在环型链表问题:判断一个链表是否存在环,例如下面这个链表就存在一个环: 例如N1->N2->N3->N4->N5->N2就是一个有环的链表,环的开始结点是N5这里有一个比较简单的解法。设置两个指针p1,p2。每次循环p1向前走一步,p2向前走两步。直到p2碰到NULL指针或者两个指针相等结束循环。如果两个指针相等则说明存在环。 struct link {     int data;     link* next; }; bool IsLoop(link* head) {     link* p1=

19、head, *p2 = head;      if (head ==NULL || head->next ==NULL)      {           return false;      }     do{         p1= p1->next;         p2 = p2->next->next;     } while(p2 && p2->next && p1!=p2);          if(p1 == p2)          

20、 return true;      else           return false; } 2,链表反转 单向链表的反转是一个经常被问到的一个面试题,也是一个非常基础的问题。比如一个链表是这样的: 1->2->3->4->5 经过反转后成为5->4->3->2->1。最容易想到的方法遍历一遍链表,利用一个辅助指针,存储遍历过程中当前指针指向的下一个元素,然后将当前节点元素的指针反转后,利用已经存储的指针往后面继续遍历。源代码如下: struct linka {      int data;      linka

21、 next; }; void reverse(linka*& head) {      if(head ==NULL)           return;      linka*pre, *cur, *ne;      pre=head;      cur=head->next;      while(cur)      {           ne = cur->next;           cur->next = pre;           pre =

22、cur;           cur = ne;      }      head->next = NULL;      head = pre; } 还有一种利用递归的方法。这种方法的基本思想是在反转当前节点之前先调用递归函数反转后续节点。源代码如下。不过这个方法有一个缺点,就是在反转后的最后一个结点会形成一个环,因此必须将函数的返回的节点的next域置为NULL。因为要改变head指针,因此我用了引用。算法的源代码如下: linka* reverse(linka* p,linka*& head) {      if(p =

23、 NULL || p->next == NULL)      {           head=p;           return p;      }      else      {           linka* tmp = reverse(p->next,head);           tmp->next = p;           return p;      } } 3,判断两个数组中是否存在相同的数字 给定两个排好序的数组,怎样高效得判断这两个数组

24、中存在相同的数字? 这个问题首先想到的是一个O(nlogn)的算法。就是任意挑选一个数组,遍历这个数组的所有元素,遍历过程中,在另一个数组中对第一个数组中的每个元素进行binary search。用C++实现代码如下: bool findcommon(int a[],int size1,int b[],int size2) {      int i;      for(i=0;i

25、tart<=end)           {                mid=(start+end)/2;                if(a[i]==b[mid])                     return true;                else if (a[i]

26、  }      }      return false; } 后来发现有一个 O(n)算法。因为两个数组都是排好序的。因此只要一次遍历就行了。首先设两个下标,分别初始化为两个数组的起始地址,依次向前推进。推进的规则是比较两个数组中的数字,小的那个数组的下标向前推进一步,直到任何一个数组的下标到达数组末尾时,如果这时还没碰到相同的数字,说明数组中没有相同的数字。 bool findcommon2(int a[], int size1, int b[], int size2) {      int i=0,j=0;      w

27、hile(ib[j])                j++;           if(a[i]

28、负数),求A1~An的一个子序列Ai~Aj,使得Ai到Aj的和最大 例如: 整数序列-2, 11, -4, 13, -5, 2, -5, -3, 12, -9的最大子序列的和为21。 对于这个问题,最简单也是最容易想到的那就是穷举所有子序列的方法。利用三重循环,依次求出所有子序列的和然后取最大的那个。当然算法复杂度会达到O(n^3)。显然这种方法不是最优的,下面给出一个算法复杂度为O(n)的线性算法实现,算法的来源于Programming Pearls一书。 在给出线性算法之前,先来看一个对穷举算法进行优化的算法,它的算法复杂度为O(n^2)。其实这个算法只是对对穷举算法稍微做了一些修改

29、其实子序列的和我们并不需要每次都重新计算一遍。假设Sum(i, j)是A[i] ... A[j]的和,那么Sum(i, j+1) = Sum(i, j) + A[j+1]。利用这一个递推,我们就能够得到下面这个算法: int max_sub(int a[],int size) {      int i,j,v,max=a[0];      for(i=0;i

30、           v=v+a[j];//Sum(i, j+1) = Sum(i, j) + A[j+1]                if(v>max)                     max=v;           }      }      return max; } 那怎样才能达到线性复杂度呢?这里运用动态规划的思想。先看一下源代码实现: int max_sub2(int a[], int size) {      int i,max=0,temp_sum=0;     

31、 for(i=0;imax)                max=temp_sum;           else if(temp_sum<0)                temp_sum=0;      }      return max; } 6,按单词反转字符串 并不是简单的字符串反转,而是按给定字符串里的单词将字符串倒转过来,就是说字符串里面的

32、单词还是保持原来的顺序,这里的每个单词用空格分开。例如: Here is 经过反转后变为: is Here 如果只是简单的将所有字符串翻转的话,能够遍历字符串,将第一个字符和最后一个交换,第二个和倒数第二个交换,依次循环。其实按照单词反转的话能够在第一遍遍历的基础上,再遍历一遍字符串,对每一个单词再反转一次。这样每个单词又恢复了原来的顺序。 char* reverse_word(const char* str) {      int len = strlen(str);      char* restr = new char[len+

33、1];      strcpy(restr,str);      int i,j;      for(i=0,j=len-1;i

34、 i=j=k;           while(restr[j]!=' ' && restr[j]!='' )                j++;           k=j+1;           j--;           for(;i

35、 restr[j]=temp;           }      }      return restr; } 如果考虑空间和时间的优化的话,当然能够将上面代码里两个字符串交换部分改为异或实现。 例如将           char temp=restr[i];           restr[i]=restr[j];           restr[j]=temp; 改为           restr[i]^=restr[j];            res

36、tr[j]^=restr[i];           restr[i]^=restr[j]; 7,字符串反转 我没有记错的话是一道MSN的笔试题,网上无意中看到的,拿来做了一下。题目是这样的,给定一个字符串,一个这个字符串的子串,将第一个字符串反转,但保留子串的顺序不变。例如: 输入:第一个字符串: "This is fishsky 's Chinese site: " 子串: "fishsky" 输出: "nc/nc.moc.fishsky.www//:ptth :etis esenihC s'fishsky si sihT" 一般的方法是先扫

37、描一边第一个字符串,然后用stack把它反转,同时记录下子串出现的位置。然后再扫描一遍把记录下来的子串再用stack反转。我用的方法是用一遍扫描数组的方法。扫描中如果发现子串,就将子串倒过来压入堆栈。 最后再将堆栈里的字符弹出,这样子串又恢复了原来的顺序。源代码如下: #include #include #include using namespace std; //reverse the string 's1' except the substring 'token'. const char* reverse(con

38、st char* s1, const char* token) {        assert(s1 && token);        stack stack1;        const char* ptoken = token, *head = s1, *rear = s1;        while (*head != '')        {               while(*head!= '' && *ptoken == *head)         

39、      {                  ptoken++;                  head++;               }               if(*ptoken == '')//contain the token               {                  const char* p;                  for(p=head-

40、1;p>=rear;p--)                         stack1.push(*p);                  ptoken = token;                  rear = head;               }               else               {                  stack1.push(*

41、rear);                  head=++rear;                  ptoken = token;               }        }        char * return_v = new char[strlen(s1)+1];        int i=0;        while(!stack1.empty())        {              

42、 return_v[i++] = stack1.top();               stack1.pop();        }        return_v[i]='';        return return_v; } int main(int argc, char* argv[]) {cout<<"This is fishsky 's Chinese site: ";        cout<

43、ttp://www. fishsky ");        return 0; } 8, 删除数组中重复的数字 问题:一个动态长度可变的数字序列,以数字0为结束标志,要求将重复的数字用一个数字代替,例如: 将数组 1,1,1,2,2,2,2,2,7,7,1,5,5,5,0 转变成1,2,7,1,5,0 问题比较简单,要注意的是这个数组是动态的。因此避免麻烦我还是用了STL的vector。 #include #include using namespace std; //remove the duplicated nu

44、mbers in an intger array, the array was end with 0; //e.g. 1,1,1,2,2,5,4,4,4,4,1,0 --->1,2,5,4,1,0 void static remove_duplicated(int a[], vector& _st) {        _st.push_back(a[0]);        for(int i=1;_st[_st.size()-1]!=0;i++)        {               if(a[i-1]

45、a[i])                  _st.push_back(a[i]);        } } 当然如果能够改变原来的数组的话,能够不用STL,仅需要指针操作就能够了。下面这个程序将修改原来数组的内容。 void static remove_duplicated2(int a[]) {        if(a[0]==0 || a==NULL)               return;        int insert=1,current=1;       

46、 while(a[current]!=0)        {               if(a[current]!=a[current-1])               {                  a[insert]=a[current];                  insert++;                  current++;               }         

47、      else                  current++;        }        a[insert]=0; } 9,如何判断一棵二叉树是否是平衡二叉树 问题:判断一个二叉排序树是否是平衡二叉树 解决方案: 根据平衡二叉树的定义,如果任意节点的左右子树的深度相差不超过1,那这棵树就是平衡二叉树。 首先编写一个计算二叉树深度的函数,利用递归实现。 template static int Depth(BSTreeNode* pbs) {       

48、 if (pbs==NULL)               return 0;        else        {               int ld = Depth(pbs->left);               int rd = Depth(pbs->right);               return 1 + (ld >rd ? ld : rd);        } } 下面是利用递归判断左右子树的深度是否相差1

49、来判断是否是平衡二叉树的函数: template static bool isBalance(BSTreeNode* pbs) {        if (pbs==NULL)               return true;        int dis = Depth(pbs->left) - Depth(pbs->right);        if (dis>1 || dis<-1 )               return false;        else               return isBalance(pbs->left) && isBalance(pbs->right); 4.abstract class Something {    private abstract String doSomething (); } 该段代码有错吗? 答案: 错。abstract的methods不能以private修饰。abstract的methods就是让子类implement(实现)具体细节的,怎么

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服