数据结构导论数据结构导论里的时间复杂度

数据结构导论  时间:2021-06-23  阅读:()

数据结构导论考试大纲

安排新计划中的“数据库系统原理”(4735)、“计算机网络原理”(4741)、“C++程序设计”(4737)、“数据结构导论”(2142)、“操作系统概论”(2323)...原计划中的加考课程“计算机原理”(2384)、“数据结构导论

自考数据结构导论……

望能对你有所帮助!

  “ 如果你想通过数据结构导论这门课,至少得看两遍书吧?”

  第一遍就是粗略的看一下,这样你心里也就有了底,也就大概的了解了数据结构导论这门课所

  讲的内容,并且那里是考点在头脑里也就都有了大致的把握,这样,你就可以带着相应的重点,去重点

  把握你觉得重要的东西了!不过其实你到现在如果连一遍也没看过呢,也没关系,我下面的总结就是希

望能对这些还没看过书的人,有所帮助!

下面就列出一些我觉得是重点的东西:

  1 ,线性表,这一章整个都比较重要,因为这一章中关于线性表的顺序实现和链接实现及在上

  面的基本运算,在最后考试中很有可能以多种形式的考法出现(如:选择,填空,应用及程序设计等)。

  并且由于这一章是整本书的基础,所以考试时占的比重会比较大,最后的程序设计题很可能就从这一章

  里出一道甚至两道都从这章里出(一道程序设计题6 分)。

这一点是我在作过大量模拟试题和分析了历

  年试卷的基础上得出的结论,应当比较有参考价值。

在这一章中有一个知识点应引起大家的注意,就是

  链式存储结构,因为这种存储结构在以后的各章中对于各种结构的实现(如:树,图等)都比较有用且

  实用。

所以对于它的掌握应当达到“ 综合应用” 的等级!(一点建议:如果你在第一次看的时候遇到了

  自己不懂的问题,可以先尝试着跳过去看后面的,等后面的看完了,再回过头看不会的这一段,问题就

  可能迎刃而解了!^ )在这一章里还有一个数据结构就是串!关于串的具体的程序编制我想就不必太

  花心思了。

(如果你学这门课不光是为了考试,并且想对串有较具体的了解的话,请参看:>,中国水利水电出版社,宁郑元主编一书)只要知道它的各种运算及结果就可以了

(考试时也就这么考了:-P )

如:DELETE(“ACABA” ,3 ,3)=?

结果为:“AC”

又如:SUBSTR(“ABBCA” ,2 ,2)=?

结果为:“BB”

  2 ,栈,队列和数组:这一章里你要掌握的东西就比较简单了(如果你掌握了上一章的内容对

  于这一章来讲,基本上就没有难题了)这一章里你要牢记两个概念:关于栈和队列的修改原则:(1 ),

  栈,后进先出,所有操作都是在栈顶进行的。

(2 ),队列,先进先出,插入运算只能在对尾进行,删

  除运算只能在对头进行!且注意对头指针指示对头元素在数组中实际位置的前一个位置;实现递归调用

属于栈的应用!

再附上关于栈和队列的几道例题如下:

  1 ,运算(* 作)是数据结构的一个重要方面,试举一例,说明两个数据结构的。

逻辑结构和

  存储方式完全相同,只是对于运算(* 作)的定义不同,因而两个结构具有显著不同的特性,是两个不

同的结构。

  答案:栈和队列的元素依次存放在一个数组中,他们的逻辑结构和存储方式完全一样,只是栈

  的插入和删除* 作只能在一端进行,而队列的插入在对尾进行,出对(删除)* 作在对首进行,因而是

两种不同的数据结构,并各自具有显著的特征。

  2 ,设有一个栈,元素进展的次序为A ,B ,C ,D ,E ,写出下列出栈序列的* 作序列。

  (1 )C ,B ,A ,D ,E ;(2 )A ,C ,B ,E ,D ;其中I 为进栈* 作,O 为出栈操作

答案:1 ,IIIOOOIOIO

2 ,IOIIOOIIOO

  3 ,树:这一章里对于不善于编制程序的你可以说是一个解脱,因为这一章和图那章都只涉及

  到了很少的程序编制,不过千万别忽视这两章,因为这两章有很多的考点……

  (1 ),关于树的一些概念:结点的度,树的度,节点的层树,树的深度等(千万别忽视这些

概念,他们可是拿分的主角啊!)

  (2 ),二叉树: 注意!二叉树是一类与树不同的树型结构!

例:判断:二叉树是树的特殊情形(X)

二叉树的性质

完全二叉树的性质

二叉树的遍历:前,中,后序遍历

其中, 两点在选择或填空中肯定会考到!

  (3 ),树和林: 树和林的存储结构①,孩子链表表示法

②,孩子兄弟链表表示法

③,双亲表示法

  其中孩子兄弟链表表示法是树和林与二叉树相互转变的关键应熟练掌握!

  树的遍历:前,后和按层次遍厉(注意与二叉树遍厉的区别)

  (4 )判定树和哈夫曼树:这一节里哈夫曼算法算是个重点,考试时有可能会在应用题中出现,

  不过应该不会考程序设计,所以掌握起来还是比较轻松的!

4 ,图

  (1 ),图的基本概念:顶点,有向图,无向图,弧,边子图,连通图,连通分量,路径,环,

网等

(2 ),图的存储结构:邻接矩阵法和邻接表法

网要用邻接矩阵法来存储

(3 )图的遍厉:深度优先搜索和广度优先搜索

  ,深度优先搜索是一个递归过程; ,广度优先搜索中,若对x 的访问先于y ,则对x

邻接点的访问也限于对y 邻接点的访问!

  (4 ),最小生成树:prim算法(很有可能会以应用题的形式出现)

  (5 ),拓扑排序:带环的有向图不能进行拓扑排序(拓扑排序是针对有向图的!)

  写到这里关于数据结构导论的所有最重点章节就都已经介绍完了,后面的三章总共加起来可能

  也就不过十几分,不过我们为了万无一失还是应该将其看完,但在后面的章节中,我们只要掌握概念性

  的东西就可以了,还值得一提的是,对于第八章排序,我们应当加以重视,各种排序方法,及稳定性还

数据结构概论作业

您好,看到您的问题一直是零回答问题且将要被新提的问题从问题列表中挤出,问题无人回答过期后会被扣分并且悬赏分也将被没收!所以我给你提几条建议: 一,您可以选择在正确的分类下去提问或者到与您问题相关专业网站论坛里去看看,这样知道你问题答案的人才会多一些,回答的人也会多些。

当然,找老师帮忙是最简单有效的方法! 二,您可以多认识一些知识丰富的网友,和曾经为你解答过问题的网友经常保持联系,遇到问题时可以直接向这些好友询问,他们会更加真诚热心为你寻找答案的。

三,很多时候该自己做的事还是必须有自己独立完成的,有的事还是须由自己的聪明才智来解决的,别人不可能代劳!就算别人给你代劳,最后也不属于你的,只有自己做了才是真正属于自己的,别人只能给你提供指导和建议,最终靠自己。

所以,祝愿你可以凭借自己的努力找到最终自己想要的结果!你是最棒的! 您可以不采纳我的答案,但请你一定采纳我的建议哦! 虽然我的答案很可能不能解决你的问题,但一定可以使你更好地使用问问哦~~~

c语言,数据结构,算法导论三本书的关系是什么,学习它们要有什么基础,以及三者学习先后次序是什么?

c语言就像鞋,数据结构就相当于走路,算法导论就像跑步 只有穿上了鞋,你才能走起来,走的熟练了才能跑起来。

否则,你会走的脚疼,虽然也能走。









数据结构导论里的时间复杂度

1. 一般情况下,算法的基本操作重复执行的次数是模块n的某一个函数f(n),因此,算法的时间复杂度记做:T(n)=O(f(n))  分析:随着模块n的增大,算法执行的时间的增长率和f(n)的增长率成正比,所以f(n)越小,算法的时间复杂度越低,算法的效率越高。

  

2. 在计算时间复杂度的时候,先找出算法的基本操作,然后根据相应的各语句确定它的执行次数,再找出T(n)的同数量级(它的同数量级有以下:1,Log2n ,n ,nLog2n ,n的平方,n的三次方,2的n次方,n!),找出后,f(n)=该数量级,若T(n)/f(n)求极限可得到一常数c,则时间复杂度T(n)=O(f(n))  例:算法:  for(i=1;i<=n;++i)  {   for(j=1;j<=n;++j)   {   c[ i ][ j ]=0; //该步骤属于基本操作 执行次数:n的平方 次  for(k=1;k<=n;++k)   c[ i ][ j ]+=a[ i ][ k ]*b[ k ][ j ]; //该步骤属于基本操作 执行次数:n的三次方 次  }   }   则有 T(n)= n的平方+n的三次方,根据上面括号里的同数量级,我们可以确定 n的三次方 为T(n)的同数量级  则有f(n)= n的三次方,然后根据T(n)/f(n)求极限可得到常数c   则该算法的 时间复杂度:T(n)=O(n的三次方)

3.分类  按数量级递增排列,常见的时间复杂度有:  常数阶O(1),对数阶O(log2n),线性阶O(n),   线性对数阶O(nlog2n),平方阶O(n2),立方阶O(n3),...,  k次方阶O(nk), 指数阶O(2n) 。

随着问题规模n的不断增大,上述时间复杂度不断增大,算法的执行效率越低。

建议:多看一些带答案的习题就理解了

轻云互联,香港云服务器折后22元/月 美国云服务器 1核 512M内存 15M带宽 折后19.36元/月

轻云互联成立于2018年的国人商家,广州轻云互联网络科技有限公司旗下品牌,主要从事VPS、虚拟主机等云计算产品业务,适合建站、新手上车的值得选择,香港三网直连(电信CN2GIA联通移动CN2直连);美国圣何塞(回程三网CN2GIA)线路,所有产品均采用KVM虚拟技术架构,高效售后保障,稳定多年,高性能可用,网络优质,为您的业务保驾护航。官方网站:点击进入广州轻云网络科技有限公司活动规则:1.用户购...

云基最高500G DDoS无视CC攻击(Yunbase),洛杉矶CN2GIA、国内外高防服务器

云基成立于2020年,目前主要提供高防海内外独立服务器用户,欢迎各类追求稳定和高防优质线路的用户。业务可选:洛杉矶CN2-GIA+高防(默认500G高防)、洛杉矶CN2-GIA(默认带50Gbps防御)、香港CN2-GIA高防(双向CN2GIA专线,突发带宽支持,15G-20G DDoS防御,无视CC)、国内高防服务器(广州移动、北京多线、石家庄BGP、保定联通、扬州BGP、厦门BGP、厦门电信、...

Buyvm:VPS/块存储补货1Gbps不限流量/$2起/月

BuyVM测评,BuyVM怎么样?BuyVM好不好?BuyVM,2010年成立的国外老牌稳定商家,Frantech Solutions旗下,主要提供基于KVM的VPS服务器,数据中心有拉斯维加斯、纽约、卢森堡,付费可选强大的DDOS防护(月付3美金),特色是1Gbps不限流量,稳定商家,而且卢森堡不限版权。1G或以上内存可以安装Windows 2012 64bit,无需任何费用,所有型号包括免费的...

数据结构导论为你推荐
贸易配额进出口配额是怎么回事情?ata考试有人能仔细讲一下ATA考试是什么吗?怎么用电脑发短信谁知道怎样能用电脑给手机发短信webservice框架用JAVA作APP后端,一般用什么web service?用什么restful框架netbios协议现在怎么还有用NetBios协议的,这个协议和TCP/IP协议有什么关系,为什么获取网卡的信息还要qq管家官网在qq电脑管家官网有个可以登录qq的。登录上了可以加速么?网络安全密钥网络安全密钥一般是什么网站客服代码怎么在网页用HTML代码设置QQ客服za是哪个国家的IE是哪个国家的缩写动画分镜头脚本动漫脚本和分镜头的区别?懂的进
子域名查询 长沙域名注册 淘宝二级域名 http500内部服务器错误 12u机柜尺寸 2017年黑色星期五 申请个人网页 三拼域名 什么是刀片服务器 qq对话框 linux服务器维护 爱奇艺vip免费领取 绍兴电信 国外视频网站有哪些 中国电信测速器 百度云加速 金主 江苏徐州移动 weblogic部署 神棍节 更多