数据结构与算法,这道难题怎么做啊,求指教

作者&投稿:延岭 (若有异议请与网页底部的电邮联系)
数据结构与算法,二叉排序树问题,这题怎么做啊,请教大神!!!~


2)换了7次,
a 右子树指向f节点;
g 左指空,父节点指f;
f 父指a,左指b,右指g;
b 父指f。
不知道e置空算不算

(1) 用单链表表示的链式队列的对头在链表的( )位置。
  (2)如果只想得到1000个元素组成的序列中第5个最小元素之前的部分排序的序列,用( )方法最快。
  (3)如果待排序序列中两个数据元素具有相同的值,在排序前后它们的相互位置发生颠倒,则称该排序算法是不稳定的。( )就是不稳定的排序方法。

  (4)线性表是具有n个( )的有限序列( n>0).

  (5)设无向图的顶点个数为n,则该图最多有( )条边。

  [供选择的答案]

  A:(1)链头 (2)链尾 (3)链中

  B:(1)起泡排序(2)快速排列(3)Shell排序(4)堆排序(5)简单选择排序

  C:(1)起泡排列(2)归并排列(3)Shell排列(4)直接插入排列(5)简单选择排序

  D:(1)表元素(2)字符(3)数据元素(4)数据项(5)信息项

  E: (1) n-1 (2) n(n-1) (3) n(n+1)/2 (4) 0 (5) n.*n

  二、双端队列(deque)是一个可以在任一端进行插入和删除的线性表。现采用一个一维数组作为双端队列的数据存储结构,使用类Pascal语言描述如下

  const maxsize=32; {数组中可容纳的元素个数}

  type deque=record

  elem: array[0..maxsize-1]of datatype; {环形队列的存放数组}

  end1,end2:0..maxsize; {环形数组的两端}、
  end;
  试编写两个算法add(Qu:duque;x:datatype;tag:0..i)和delete(Qu:duque; var x:datatype; tag:0..1)用以在此两端队列的任一端进行插入和删除。当tag=0时在左端 endl端操作,当tag=1时在右端end2端操作。

首先,要能够读懂代码,总结算法的思想,搞清楚该题算法是完成什么功能,然后是填空也好,写算法结果也好,就不成问题了。要想提高的快,就得多练啊。同时教材中的相关算法也要熟,好多是书中的原算法
1. 在计算机中,算法是指什么?
答案:解题方案的准确而完整的描述。
2. 在下列选项中,哪个不是一个算法一般应该具有的基本特征?
说明:算法的四个基本特征是:可行性、确定性、有穷性和拥有足够的情报。 答案:无穷性。
3. 算法一般都可以用哪几种控制结构组合而成? 答案:顺序、选择、循环。 4. 算法的时间复杂度是指?
答案:算法执行过程中所需要的基本运算次数。 5. 算法的空间复杂度是指?
答案:执行过程中所需要的存储空间。 6. 算法分析的目的是?
答案:分析算法的效率以求改进。 7. 下列叙述正确的是(C)
A.算法的执行效率与数据的存储结构无关
B.算法的空间复杂度是指算法程序中指令(或语句)的条数 C.算法的有穷性是指算法必须能在执行有限个步骤之后终止 D.算法的时间复杂度是指执行算法程序所需要的时间 8. 数据结构作为计算机的一门学科,主要研究什么?
答案:主要研究数据的逻辑结构、对各种数据结构进行的运算,以及数据的存储结构。 9. 数据结构中与所使用的计算机无关的是数据的(C) A.存储结构 B.物理结构
C.逻辑结构 D.物理和存储结构 10. 下列叙述中,错误的是(B)
A.数据的存储结构与数据处理的效率密切相关 B.数据的存储结构与数据处理的效率无关
C.数据的存储结构在计算机中所占的空间不一定是连续的 D.一种数据的逻辑结构可以有多种存储结构 11. 数据的存储结构是指什么?
答案:数据的逻辑结构在计算机中的表示。 12. 数据的逻辑结构是指?
答案:反映数据元素之间逻辑关系的数据结构。
13. 根据数据结构中各数据元素之间前后件关系的复杂程度,一般将数据结构分为? 答案:线性结构和非线性结构。
14. 下列数据结构具有记忆功能的是(C) A.队列 B.循环队列 C.栈
D.顺序表
15. 下列数据结构中,按先进后出原则组织数据的是(B) A.线性链表 B.栈
C.循环链表 D.顺序表


数据结构与算法设计:Pascal语言内容简介
书中深入浅出地介绍了排序法、搜索策略、分治策略、贪心法和动态规划等算法,这些都是算法设计的重要组成部分。特别值得一提的是,每一章都配有A、B两级习题,旨在帮助读者逐步提升技能,习题后还附有详细的参考答案,便于自我检验和理解。这本书的结构严谨,语言精炼,无论对于正在参加信息学奥赛的学生...

数据结构与算法之美笔记——散列表(上)
两个相等的数据经过散列算法得到的散列值肯定相等,否则利用散列值在散列表中查找数据就无从谈起;至于...散列表搬移的操作肯定会降低散列表的操作效率,那能不能对这一过程进行改进?其实可以将低效的扩容操作分摊...装载因子的增高也只是意味着槽位对应的链表更长而已,链表增长也有将链表改造为跳表等结构的应对策略,...

数据结构与算法分析 —— C 语言描述:开放定址法
分离链接散列算法的缺点是需要指针,由于给新单元分配地址需要时间,因此这就导致算法的速度多少有些缓慢,同时算法实际上还要求实现另一种数据结构。除使用链表解决冲突外,开放定址散列法(open addressing hashing)是另外一种用链表解决冲突的方法。在开放定址散列算法系统中,如果有冲突发生,那么就要尝试...

求数据结构与算法分析高人帮忙做下这几道题目。(希望能给出正确答案,在...
填空题 1. n-1 因为队尾指针总是指向空。2. 1 因为无向图的邻接矩阵是对称的。3. 61 元素数量= (rear+max-front) 当front > rear (front+max-rear) 当rear > front 4. 深度优先搜索算法 5.判断题 1. F 二叉树就可以用数组存储。2. F 当发生冲突时,它要在下一个位置找,但如果该...

数据结构与算法分析
例如,求解梁架结构中应力的数学模型的线性方程组,可以使用迭代算法来求解。由于当时所涉及的运算对象是简单的整型、实型或布尔类型数据,所以程序设计者的主要精力是集中于程序设计的技巧上,而无须重视数据结构。随着计算机应用领域的扩大和软、硬件的发展,非数值计算问题越来越显得重要。据统计,当今处理...

【算法和数据结构】—列表
列表,这个看似简单的数据结构,其实操作效率的关键在于其处理方式,尽管它与栈、队列在形式上相似,但处理逻辑有所不同。本文将主要聚焦于列表的探讨。在编程解决问题时,第一步是抽象问题,我们需要理解“列表”的核心属性。例如,它包含哪些基本特征和行为。根据这些抽象的数据特性,我们可以设计并定义列表...

什么是算法与数据结构
因此,为了编写出一个“好”的程序,必须分析待处理的对象的特征及各对象之间存在的关系,这就是数据结构这门课所要研究的问题。众所周知,计算机的程序是对信息进行加工处理。在大多数情况下,这些信息并不是没有组织,信息(数据)之间往往具有重要的结构关系,这就是数据结构的内容。数据的结构,直接影响算法的选择和效率...

数据结构和算法有什么关系?数据结构就是算法吗?
数据结构是数据间的有机关系,算法是对数据的操作步骤。这两个概念间的逻辑关系贯穿了整个程序世界,首先二者表现为不可分割的关系。没有数据间的有机关系,程序根本无法设计,例如,设计a+b的程序,你总得找到a和b的值吧,a和b必须是可以互相找到的才能进行程序运算,a和b就必然要联结成一定的关系,...

数据结构与算法在计算机领域或行业之中到底占据着什么样的重要地位...
平时用到的算法主要存在两个方面的原因:一种是里面涉及的编程里面可以用更好的算法来代替但是本身由于意识层面的问题,感觉不到可以采用更加优秀的算法,时间久了忽略了算法的真实存在;第二种本身工作上触及到的算法比较少,感受不到算法的重要性。数据结构和算法在实际编程中作用算法一般用在图形换算或者...

帮忙做个关于数据结构与算法的题(用java语言描述),谢谢!
题目只提供了isPresent方法的spec,没有讲其他的,尤其是insert方法,参数是什么,是否需要多个重载?是在指定位置插入呢,还是怎样?remove方法也是,是根据元素删除呢,还是根据下标删除?另外,这个题目就是自己写一个ArrayList,楼主要是不会的话,可以自己参考JDK中java.util.ArrayList类的实现 ...

道里区19595596436: 数据结构与算法的题目,怎么做? -
邸毓清脂: 首先,要能够读懂代码,总结算法的思想,搞清楚该题算法是完成什么功能,然后是填空也好,写算法结果也好,就不成问题了.要想提高的快,就得多练啊.同时教材中的相关算法也要熟,好多是书中的原算法 1. 在计算机中,算法是指什么...

道里区19595596436: 一道数据结构与算法的题目,怎么做? -
邸毓清脂: (1) 用单链表表示的链式队列的对头在链表的( )位置. (2)如果只想得到1000个元素组成的序列中第5个最小元素之前的部分排序的序列,用( )方法最快. (3)如果待排序序列中两个数据元素具有相同的值,在排序前后它们的相互位置发生...

道里区19595596436: 数据结构与算法好难啊!怎样才能把它们学好呢?希望前辈能指点迷经!
邸毓清脂: 还好,也不是很难.就是多看一些练习啊,再自己多想想,寻找感觉就好了.感觉很重要的!

道里区19595596436: 数据结构这么难怎么学 -
邸毓清脂: 1 需要有一些编程语言基础,对函数、数组、结构体、指针等比较了解;2 先大概看一下一遍数据结构的书籍,先把书上的内容按难度分一下类,如:容易,比较难,很难,先把容易的学会,再学习难一些的,再学习更难的~3 在看书的时一定要自己编程,再上机调试,把书上结构体和算法用程序实现,一定要把课后的练习题全部做完,做对,理论和实践结合起来;4 要多借鉴他人的经验,学习的过程中多与别人交流,多看一下别人的学习笔记和心得;5 态度决定一切,要用心去学,逐步的去理解,享受学习过程~ 祝你学得开心~

道里区19595596436: 考研的数据结构怎么复习啊!桂求复习方法 -
邸毓清脂: 数据结构是计算机存储、组织数据的方式.数据结构是指相互之间存在一种或多种特定关系的数据元素的集合.通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率.数据结构往往同高效的检索算法和索引技术有关. 一、重难点...

道里区19595596436: 怎么学好数据结构与算法,好难啊 -
邸毓清脂: 数据结构重点在于对结构的理解,程序倒是次要的.很多人认为难,是因为看到C语言里面的指针.其实用Java也可以写.别忘记了,拿高工次的人都是策划的牛的,而不是写程序牛的.

道里区19595596436: 数据结构与算法怎么样才能学好
邸毓清脂: 一要把概念搞清楚 二他怎么做有什么好处 三把书上的算法在机子上实现一边 凭自己的理解 尽量不看书 四找一个可以用这个算法的题目 自己做一边 不看书 五与之前学过的类似的算法比较 比较它们之间的时间复杂度、空间复杂度和适用范围

道里区19595596436: 一道数据结构题目 算法
邸毓清脂: 过程的目的就是使得x,y,z,成为递减的顺序 首先判断x,y,如果x,y不是递减,即x<y,那么交换x和y,这样就保证了x,y是递减的顺序,即x>=y 然后判断y和z的顺序,如果y和z已经保证递减顺序,也就是y>=z的话,那么什么也不用做,因为这是x,y,z肯定是递减关系了 如果y<z的话,那就要看x和z谁大谁小,如果x比较大,那么顺序就是x,z,y,所以要交换z和y.如果z比较大,那么顺序就是z,x,y,那么三个数都要变:y=x,x=z,z=y 当然所有的交换都要引入临时变量temp 另外,从小到大很简单,只要输出的时候反过来就可以了,本来是顺序输出x,y,z,现在是顺序输出z,y,x

道里区19595596436: C数据结构与算法课程设计题求解!急急急!!!Project4.8
邸毓清脂: 用无序表实现城市数据库.用顺序表实现时,如果你用的是数组,我想最多的问题是受到数组长度的限制,不好把握数组的大小.如果用链表实现,在你硬件允许的情况下,可以不受限制的添加记录,但是要比顺序表消耗更多的空间,用于存放指针.至于按照城市的字母顺序存储记录,使线性表成为有序,只要你算法设计的好可以很大的提高你的查询速度,但是并会对你的插入和删除造成影响,因为你每次插入和删除都要对线性表进行排序,会造成你插入和删除数据的速度减慢.所以如果你的设计用于查询多的话,你可以考虑有序的,但如果是插入和删除多的话,建议还是用无序的好.

道里区19595596436: 数据结构问题: -
邸毓清脂: (1)tail(tail(head(L1))); (2)head(head(tail(tail(head(head(L2)))))) 要特别注意L2中(C)与C是不同的概念.

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网