2014年848数据结构真题复习

news2024/11/29 9:57:08
  1. 求k++频度
    
    K=0;
    for(i=1;i<=n;i++)	假如是1——8,执行了9次,8次有效,最后一次无效
     	for(j=i;j<=n;j++)
     		  k++
    我的理解:
     假设n为8
     我们看k++频度实际上就是看内圈for的有效循环次数
     第一轮是1——8	八次有效循环 
     第二轮是2——8	七次有效循环
     第三轮是3——8	六次有效循环
     第四轮是4——8	五次有效循环
     第五轮是5——8	四次有效循环
     第六轮是6——8	三次有效循环
     第七轮是7——8	二次有效循环
     第八轮是8——8	一次有效循环
     如果数字n很大,没有时间画到循环结束
     8-1+1
     8-2+1
     8-3+1
     8-4+1
     ...
     8-8+1
     n-i+1就是规律
    

    你只需要把前面几次循环的次数求出来,把最后几次循环的次数求出来,基本上都可以用等差求和公式计算出结果

    所以上面的每次的执行次数相加就是
    1+2+3+....n
    =[n(n+1)]/2 次
    时间复杂度是O(n^2)
    
  2. 数据元素是数据的基本单位

  3. 顺序表,删除表尾元素,时间复杂度是O(1)

  4. 顺序表,删除表头元素,时间复杂度是O(n)

  5. 长度为n的顺序表,删除某一个元素,平均需要移动(n+1)/2个元素

  6. 长度为n的顺序表,删除第i个元素,需要移动n-i个元素

  7. 长度为n,n表示元素个数,下图n为6,删除第i个,下图i是第3个元素,那就要移动i+i到n这些元素,所以移动n-i个元素
    在这里插入图片描述

  8. 入栈push(&S,e),是将e这元素插入到栈顶

  9. A有3个兄弟,B是A的双亲,B的度是4
    在这里插入图片描述

  10. 含有1000个节点的二叉链表中有几个空链域
    我的理解:下图有7个节点,每个节点2个指针域,7个节点要6个指针域连接起来,那1000个节点,就有2000个指针域,其中1000个节点需要999个指针域来连接,那就剩下2000-999个节点是空的也就是1001个节点是空的,n个节点的二叉链表,有n+1个空链域
    在这里插入图片描述

  11. 深度为10的满二叉树有几个节点:1023个
    我的理解:满二叉树,就是编号从上至下,从左至右,变大
    除了最后一层有叶子节点,其他层的子节点都是两个,深度为k的满二叉树的节点总数是(2^k)-1
    第i层上有2^(i-1)个节点,满二叉树的叶子节点有
    2 ^ (k-1)个
    在这里插入图片描述

  12. 静态查找中的折半查找,找到20需要几次
    {5,8,11,12,15,20,32,41,57}
    我的理解:一共9个数,下标从0到8
    先找第一个数(0+8)/2向下取整还是为4,下标为4的数是15,是找的第一个数,20比它大,就从15的右边开始
    第二次找,依然是下标带入计算,(5+8)/2向下取整为6,下标为6的数是32,20比他小
    第三次找(5+5)/2向下取整为5,下标为5的就是20,找了3次
    在这里插入图片描述

  13. 循环队列
    1.判断队列满(r,f是下标)
    看图下,r的位置不能放元素,是一个队列满状态,队列满的公式是(r+1)%Maxsize==f
    Maxsize表示有几个格子
    下图Maxsize=6,f=0,r为5,(5+1)%6=0


队列为空时 r==f
进来一个元素,先判断队列是否满
没满就 r=(r+1)%Maxsize
在这里插入图片描述
出队,先判断队列是否为空,队列为空拿什么出队
不为空
f=(f+1)%Maxsize
在这里插入图片描述
判断某一时刻循环队列的长度,也就是求队列中元素个数
如果r>f (r,f是下标)
就用r-f
5-3=2
在这里插入图片描述
如果此时r<f
就用r-f+Maxsize
0-3+6=3
在这里插入图片描述
中和上述两种情况
公式就是(r-f+Maxsize)%Maxsize

  1. 某二叉树的中序遍历为BDCEAFIHJG,后序遍历为DECBIJHGFA,画出二叉树,然后写出先序遍历
    先序遍历:ABCDEFGHIJ
    请添加图片描述

  2. 八个权值构造哈夫曼树{30,70,15,10,20,35,50,60},求带权路径长度
    请添加图片描述

  3. 将深林转换为二叉树 节点左边是孩子,右边是兄弟
    在这里插入图片描述
    在这里插入图片描述

  4. 关键字序列{50,100,60,50,30,20,25,30,90}构造二叉排序树,求查找平均长度(相同的数字,如果已经在图中,就不用再进入图中了)
    请添加图片描述

  5. 一组关键字序列构造哈希表{19,14,23,1,68,20,84,27,55,11,10,79}哈希函数为
    H(key)=key MOD 11,表长为11,采用链接地址冲突法
    我的理解:用每一个数去与11取模
    19%11=8 19在下标为8的格子下面,
    在这里插入图片描述
    14%11=3 则14在下标为3的位置
    如果遇到一个数25,25%11=3 25也在下标为3的位置,这里就用冲突解决办法,题目的冲突解决办法是链接地址冲突法就是把25放在14下面
    在这里插入图片描述
    重复上面的步骤 结果如下
    在这里插入图片描述

    ASL成功:
    蓝色的框里的9个元素只查找1次就找到,红色框里的3个元素查找2次就找到
    求的是每个元素的查找平均率嘛,除元素总个数
    ASL成功=(1x9+2x3)/12=1.25
    

    在这里插入图片描述

    ASL失败:
    0号格子找第三次时才为空,所以第一个格子下标为0的查找失败为3
    ASL失败=(3+3+3+2+1+2+1+2+2+2+2)/11
    这里注意:
    查找失败要除表长
    查找成功要除元素个数
    

    在这里插入图片描述

  6. 下图是无向图的邻接表
    从C开始求深度优先
    从C开始求广度优先
    在这里插入图片描述
    深度优先就是一条路走到黑,到黑了就退一步,又走到黑
    深度优先:C——B——A,再从A返回到B,从B的第二个节点继续走到底,B的第二个节点是3,C是不是3,也被访问过了,再去找B的第三个节点,B的第三个节点是2,2代表E,E之前没被访问过,所以接在序列后面就是C——B——A——E,E的第一个节点是0,已经被访问了,E的第二节点是3也被访问了,所以从E退回到B,B的节点是不是被访问完了,所以从B退回到C,接着去找C的第二个节点,没有问题吧。C的第二个节点是4,也就是D,D之前没被访问,所以接在序列后面就是C——B——A——E——D
    在这里插入图片描述
    我理解的深度优先,从A开始,我画的这种深度优先遍历只是其中一种,还有很多种走法,蓝色是走,红色是遇到死胡同就回退
    在这里插入图片描述
    下图 广度优先:C先看见了三个元素,C——B——D——E,B中又看见了A
    在这里插入图片描述
    广度优先比较简单,A先看见了B和H,则序列为A——B——H。先看的B,后看见的H,那I,J写在M,C后面 序列号为A——B——H——M——C——I——J
    在这里插入图片描述

  7. 快速排序:
    快速排序以第一个或者最后一个数为基准,我取第一个数为基准,大于第一个数,去右边,小于第一个数的去左边,
    我的理解:大于X的放右边,小于X的放左边,等于X的数,随意放
    类似于把棍子掰成左右两段,左段又掰成两段,右段又掰成两段

    void offcn(int A[],int left,int right)#创建一个方法,数组A,传入left,right
    {
    	int i=left;我认为:left和right是每次掰成两段的首尾值,下一轮的left和right需要依靠本轮的left和right求得,所以需要i,j来工作
    	int j=right;
    	int temp=A[left];temp是第一个元素,第一个元素就可以被覆盖,也就是i下标所在的值被覆盖,这样就达到了移动元素排列顺序的目的
    	while(i<j)
    	{
    		while(i<j&&A[j]>temp)	以中间为分界,在右半部分只要找到一个数小于temp,为什么是temp呢,快速排序以第一个或者最后一个数为基准,我取第一个数为基准,大于第一个数,去右边,小于第一个数的去左边,我在右边找到一个数小于基数temp,我就把这个数覆盖第一个数,记住第一个数是不是已经被temp保存了啊,所以随便覆盖。我在右边找啊找,每个数都大于第一个数,记住右半部分是从右向左找噢,所以j--,左半部分是从左向右找,所以i++,终于找到一个数小于第一个数了,这就表示不满足while循环啊,所以跳出循环啊,执行赋值语句啊。懂了没
    			j--;
    		A[i]=A[j];
    		while(i<j&&A[i]<temp)	从左边找出一个大于基数temp,我找啊找,每一个数都小于temp,我继续找,找到了一个数大于temp,我就跳出循环不找了,要把这个大的数赋值到哪里哩,你想想你上面是不是把一个小的数赋值到前面来了,那它是不是可以被覆盖,它在哪,是不是在下标为j的位置。我可没动过j啊,所以之间赋值过去
    			i++				
    		A[j]=A[i]
    	}
    	A[i]=temp;
    	offcn(int A[],int left ,int i-1);
    	offcn(int A[],int i+1 ,int right);
    }
    
  8. 在带头结点的单链表L中的第i个位置前插入元素e

    我的理解:
    L不能动,让工作指针P去移动,
    移动到哪里算是个头呢
    移动到i的前面就到头了是不是
    那就是说假如一个变量不再小于i-1了,这个变量必定在i的左手边
    if(j<i-1)	
    	p=p.next
    但你也不知道要执行几次才找到i的左边,所以p的移动用循环,一直找,直到找到
    while(j<i-1)	
    	p=p.next
    

    在这里插入图片描述
    还有一个问题,假如我让你插在单链表L的第1000个位置,可上图没1000个节点怎么办?这种情况下j(j初始为0)永远小于i-1,p走到链表底时,p.next=空,所以当p为空了,再执行就没意义了

    if(!p)
    	return	"i有误"		#p不为空,!p就表示空,p都为空了,还没找到i,那i就有问题
    
    得在循环条件里加一个限制语句
    while(p&&j<i-1)这里表示p不为空且j<i-1时,p向右移动
    	p=p.next	
    让他一直执行,一直执行,执行到不满足条件就代表p指向了i的左边的节点
    

    还有一个问题,假如我让你插在单链表L的左边第100个位置,可上图的链表就是从L开始的,L左边没有节点,所以这有问题

    if(j>i-1)
    	return “i有误”
    

    综合一下

    if( !p  ||  j>i-1)	
    	return  "ERROR";
    

    如果找到了,那么P已经指向了i的前驱,
    然后插入新节点S:

    S.next=P.next
    P.next=S
    i不是指针,如果p的下一跳先指向s,那i节点就不见啦嘿嘿
    

    在这里插入图片描述

    静态查找:1.顺序查找,折半查找,分块查找

  9. 顺序存储中顺序查找

    typedef sturt
    {
      	Elemtype *elem;我的理解:*elem是一个任意类型的指针
    	int lenght;		元素个数
    }ABC;
    
    int search(ABC &L,int key)
    {
       int i;
       L.elem[0].key=key;#将传进来的值放在L.elem顺序表的开头,你也可以放在表尾巴
       for(i=L.lenght;L.elem[i].key!=key;--i)#i从顺序表里最后一个元素开始,每一个与x比较
       return i;
    }
    
  10. 折半查找

    typedef sturt
     {
     	Elemtype *elem;我的理解:*elem是一个任意类型的指针
     	int lenght;		元素个数
     }ABC;
    
    int dsfsdsd(ABC &L,int lenght,int key)	长为lenght的顺序表,传进来一个key值
    {
    	int min	mid	max;		小中大,用来折半
    	min=0;			min在最左边
    	max=L.lenght;	max在最右边
    	while(min<max)	min小于max时,可以求中间值
    	{		
    		mid=(min+max)/2;	也可以是mid=min+[(max-min)/2]
    		if(key=L.elem[mid])
    			return	mid;
    		else
    			if(key>L.elem[mid].key)	看key在右半部分,还是左半部分
    				min=mid+1;		只需要改变min,就继续开始新一轮折半
    			else
    				max=mid-1;
    	}
    	return 0;
    }
    
  11. 用函数返回二叉树的叶子节点个数

    int count(BiTree T)
    {
    	int num=0;计数器
    	if(T==NULL)	没有根
    		return 0;
    	if(T->lchild==NULL&&T->rchild==NULL)左孩子右孩子都是空自己就是叶子,然后加1
    			num++;
    	count(T->lchild);			把左叶子节点调进去再判断,左孩子是空就不调进去
    	count(T->rchild);			把右孩子节点调进去再判断
    	return num;
    }
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/3390.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基础算法 第七课——归并排序

文章目录导言归并排序的概念步骤说明逐步分析STEP1STEP2STEP3STEP4STEP5STEP6STEP0总结导言 这&#xff0c;是一篇现学现卖的文章。因为&#xff0c;我根本没学过归并排序。所以&#xff0c;这篇文章&#xff0c;绝对能让您学懂归并。如果不懂&#xff0c;那我就再学一遍&…

KVM Forum 2022应该关注的话题

1. QEMU 和 KVM 自动性能基准测试 QEMU & KVM Automated Performance Benchmarking SUSE - Dario Faggioli, SUSE SUSE正在开发一个框架&#xff0c;用于对虚拟化工作负载进行自动性能基准测试。它是围绕着MMTests&#xff08;已经在Linux内核社区使用了几年&#xff09;建…

2022-Java 后端工程师面试指南 -(SSM)

前言 种一棵树最好的时间是十年前&#xff0c;其次是现在 Tips 面试指南系列&#xff0c;很多情况下不会去深挖细节&#xff0c;是小六六以被面试者的角色去回顾知识的一种方式&#xff0c;所以我默认大部分的东西&#xff0c;作为面试官的你&#xff0c;肯定是懂的。 上面的…

Mybatis之foreach

文章目录一、foreach属性二、使用foreach批量删除(法一)1.接口2.mapper文件3.测试类4.运行结果三、使用foreach批量删除(法二)1.mapper文件四、使用foreach批量插入1.接口2.mapper文件3.测试类4.运行结果一、foreach属性 collection&#xff1a;指定数组或者集合 item&#xf…

FPGA时序约束01——基本概念

前言1. 越来越多的时序问题 随着FPGA时钟频率加快与其实现的逻辑功能越来越复杂&#xff0c;开发者遇到的问题很多时候不再是代码逻辑的问题&#xff0c;而是时序问题。一些开发者可能有这样的经历&#xff0c;一个模块在100MHz时钟运行没问题&#xff0c;而将时钟频率改为150…

【仿牛客网笔记】 Spring Boot进阶,开发社区核心功能-事务管理

添加评论中会用到事务管理。 解决的程度不同&#xff0c;层级不同。我们一般选择中间的级别。 选择时既能满足业务的需要&#xff0c;又能保证业务的安全性&#xff0c;在这样的前提下我们追求一个更高的性能。 第一类丢失更新 图中是没有事务隔离的情况 第二类丢失更新 脏…

需求工程方法的学习

作业要求&#xff1a;总结尽可能多的需求工程的方法和技术&#xff0c;要求归纳总结各种方法的适用场景、优缺点等。说明&#xff1a;其中需求工程包括需求获取、需求分析、规格说明、验证、管理等。只要是用于需求工程相关的技术和方法都可以算。 软件需求工程划分为需求开发…

Linux 中 man手册中函数后面括号数字释义

文章目录简介参考资料简介 Linux手册页项目记录了用户空间程序使用的Linux内核和C库接口。 用man手册查看系统命令&#xff0c;系统调用&#xff0c;glibc函数时&#xff0c;会发现其后面会有个括号&#xff0c;括号里面是一个数字&#xff0c;比如&#xff1a; access(2), …

一文了解Spring框架

目录 SpringBoot VS Servlet Spring是什么&#xff1f; loC&#xff1a;控制反转 DI 创建一个Spring项目 创建一个Spring IOC容器 注册Bean对象 获取Bean对象 注意事项&#xff1a; 类注解 为什么有这么多类注解&#xff1f; 注册与注入 方法注解 Bean Spr…

《R语言数据分析》2022-2023第一学期课程分析报告

1 (30分)基本操作题 1.1 (10分) 请写出下面问题的R代码 1.(2分)安装并加载gtools扩展包。 install.packages(“gtools”) library(gtools) 2.(2分)查看当前已经加载的所有包。 as.data.frame(installed.packages())$Package 3.(2分)查看gtools包的帮助网页。 ?gtools…

《清单革命》内容梳理随笔

《清单革命》内容梳理&随笔 起 书即是将四散的知识按照逻辑和网状联系编排起来。你应该这样去读&#xff0c;高屋建瓴、层次有秩、显得貌似自己有经验&#xff08;褒义&#xff09;的读&#xff0c;读出一些感想和方法论&#xff0c;无论是读出书里的还是书外的&#xff…

【MySQL高级】SQL优化

5. SQL优化 5.1 大批量插入数据 环境准备 &#xff1a; CREATE TABLE tb_user_2 (id int(11) NOT NULL AUTO_INCREMENT,username varchar(45) NOT NULL,password varchar(96) NOT NULL,name varchar(45) NOT NULL,birthday datetime DEFAULT NULL,sex char(1) DEFAULT NULL,…

【数据库】实验五 数据库综合查询|多表查询、聚集函数、orderby、groupby

文章目录参考文章本文在实验四的基础上增加了orderby、聚集函数、groupby、多表查询的知识点&#xff0c;相较于上一次实验的难度变大了&#xff0c;嵌套表达更多了&#xff0c;逐渐开始套娃…… 其实可以看成一个偏正短语来拆分&#xff0c;再写成SQL语句&#xff0c;比如查询…

微信小程序|基于小程序实现人脸数量检测

一、文章前言二、具体流程及准备三、开发步骤四、完整代码一、文章前言 此文主要通过小程序实现检测图片中的人脸数量并标记出位置信息。 当近视的小伙伴看不清远处的人时&#xff0c;用小程序一键识别就可以在手机上看清楚啦&#xff0c;是不是很实用呢。 典型应用场景&#x…

2022年还在做手动测试?是该好好反思了

为什么会写这篇文章呢&#xff1f;主要是前段时间有个朋友在QQ上和我交流&#xff0c;说他干了10年的手工测试了&#xff0c;现在还能不能转行。 说实话&#xff0c;当时我听完非常惊讶&#xff01;由此&#xff0c;我写了今天这篇文章。内容纯属个人观点&#xff0c;如果对你…

STM32CubeMX学习笔记(46)——USB接口使用(HID自定义设备)

一、USB简介 USB&#xff08;Universal Serial BUS&#xff09;通用串行总线&#xff0c;是一个外部总线标准&#xff0c;用于规范电脑与外部设备的连接和通讯。是应用在 PC 领域的接口技术。USB 接口支持设备的即插即用和热插拔功能。USB 是在 1994 年底由英特尔、康柏、IBM、…

浅刷牛客链表题,逐步深入链表,理解链表

作者&#xff1a;渴望力量的土狗 博客主页&#xff1a;渴望力量的土狗的博客主页 专栏&#xff1a;手把手带你刷牛客 工欲善其事必先利其器&#xff0c;给大家介绍一款超牛的斩获大厂offer利器——牛客网 点击免费注册和我一起刷题吧 目录 1、反转链表 2、删除链表的倒数第n个…

RocketMQ 消息重新投递 解析——图解、源码级解析

&#x1f34a; Java学习&#xff1a;Java从入门到精通总结 &#x1f34a; 深入浅出RocketMQ设计思想&#xff1a;深入浅出RocketMQ设计思想 &#x1f34a; 绝对不一样的职场干货&#xff1a;大厂最佳实践经验指南 &#x1f4c6; 最近更新&#xff1a;2022年11月4日 &#x…

35、Java——一个案例学会Dao+service层对数据表的增删改查

✅作者简介&#xff1a;热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;乐趣国学的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏&#xff1a;Java案例分…

deployment html--->JDBC--->mysql

spec: 相关属性定义 spec.selector: 符合该条件的收到该deployment管理 #spec.selector.matchLables 和 spec.template.metadata.labels 标签要一致 mysql Service metadata.name: Service的服务名 spec.ports: 虚拟端口 spec.selector: 哪些pod&#xff08;实列&…