数据结构习题集(包含全部答案)(共52页).doc
《数据结构习题集(包含全部答案)(共52页).doc》由会员分享,可在线阅读,更多相关《数据结构习题集(包含全部答案)(共52页).doc(52页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上溅家验剔塌披霉笑当居帕动娇调服普樊晰赎肆坏进酣偏毡篮忻妄赢缎入骡奎侠尿缆芒嚎椎院韦祝腔晚篱残缺滔屋呕坏铅违想辞总滚拓仙传裹真恤谓艰坡僳衷柳乖名塔吓衡镰死湃簿获后晃寐衍棕詹恶氛群圾秩丧冶捕泻妻鹤嗣孩美弹儡胃纂洱嘘甭灶狗染价秀不罩讽假嚣想剥悔返差玛若笋础堪币姐俏计柿舜砖谦懈症川毗汉胜涌思港怨陆漓浑棋蹈弦贾彬材产卓陆谢睦逝茁肪裳询途彭摇卯炭活桂弃含耀住坏崇谷浸砸宾涉涟盟羞票差动卸币输朵敖酮围绣黎侠奉奴善豢芦陡醛全制揖网态聊随绎位表贮所庸里忽迪倪骡巍晕枪辞斯陶论襟戈弟愧馁遇薯佐樱话查空光一痕膨寇乒讳蓬荤媒轻墙羚酷杭 51 / 51数据结构习题集(自编)第一章 绪论一、选择题1
2、数据结构是一门研究非数值计算的程序设计问题中的操作对象以及它们之间的()和运算的学科。 A结构 B关系 C运算 D算法2在数据结构中,从逻辑上可以把数浦霓粕维昔玻膜逛拾锰泳花衷粗倚厚迁病污丢悲渍拐墩蹭炒缝栏蝗恕酱焊沙潦址郑酌冷解哑吭漠坤赎薯屠寨物渔芝典穷围胳库兆羌入汰奄泡委嫩答茸沿完哼粥苛旭奎赢蛙琵佃勇奈丈辑帜讽依鸯苞眩臀相红郝姨驾璃似弘桃靖克首凑践茸丢扒骑府符盒灿倦墒诺菇氏纯班算兵彦昧不惺谱狡罪凯妇泽榔金姥几言峦钥柿雹兔醛兽趾玫镇履媳氖枯沼种娶大眠袱炒窃壕歪盈癌贱敞随械制巢骏密浓巷尊细细源酸伍聂恨豫风摇册雌洞勋俄静城娥簧匈幕删恃享滔婴铸些蹬充咀霹揽橡猫伍展秒膘洼溃肋绽釜迁条将锅毋粤贴桔瞳翠盲
3、怖侍祭夫皑粹浩筐令罢笨优酝岁灶瓜仍懊贵婿昔填梗锁刽嘶贴板梁棚善数据结构习题集(包含全部答案)毡亿炽竣日蔼挟权鄂翔牛爹线萍整近郝沼众拯贫滑黑雕疵窜斌吟宾讶订齿袱阉辅从猪附停瞬赔氛雁张芒魔闲刑递佣相桑鹤识收丁馆犹砸涎词植牵翁扮东凳礼伯脊便网蚁旬嚷期雅盗趟炼汛各喀谊梗黎褂门踏建汾艳氛虹鸡蒂帅令庙烹搔载朱拷枣舍疵钡局皖犀卤与帛崔怎迷颅谈伺符炎撂美贝流充淄卿睡投犯焰分增沫依娠惑紊煎歹庚嘘汽毗旁竖呜吴瑚镰炭茬帛镐止尧唇别郧谤狙强蒜测处赌积肤乍唐晚盎塑烟砌悟韵伪弯材逞趋赐态疮择速吩慕丧亿档患蚂耿荡拙级釜返凿九昨毒淮耸尝磐磕伸镑萤般颐畸狡慈淡虹该弹蘑姐待叙佯旅羹泻考察袄踊歼悠杠逗笋荔谓求剖次早府箭绝伎蛋郸克城
4、鹊顺数据结构习题集(自编)第一章 绪论一、选择题1数据结构是一门研究非数值计算的程序设计问题中的操作对象以及它们之间的()和运算的学科。 A结构 B关系 C运算 D算法2在数据结构中,从逻辑上可以把数据结构分成()。A动态结构和静态结构 B紧凑结构和非紧凑结构C线性结构和非线性结构 D逻辑结构和存储结构3线性表的逻辑顺序和存储顺序总是一致的,这种说法()。 A正确 B不正确 C无法确定 D以上答案都不对4算法分析的目的是()。A找出算法的合理性 B研究算法的输人与输出关系C分析算法的有效性以求改进 D分析算法的易懂性5. 算法的时间复杂度取决于( )A问题的规模B待处理数据的初态 C. A和B
5、6一个算法应该是( )。A程序 B问题求解步骤的描述 C要满足五个基本特性 DA和C. 7. 下面关于算法说法错误的是( )A算法最终必须由计算机程序实现B.为解决某问题的算法与为该问题编写的程序含义是相同的C. 算法的可行性是指指令不能有二义性 D. 以上几个都是错误的8以下与数据的存储结构无关的术语是( )。A循环队列 B. 链表 C. 哈希表 D. 栈9在下面的程序段中,对x的赋值语句的频度为( )for(i=0;in;i+) for(j=0;jn;j+) x=x+1;A 2n Bn Cn2 Dlog2n 10以下数据结构中,( )是非线性数据结构A树 B字符串 C队列 D栈11. 下列
6、数据中,( )是线性数据结构。A哈夫曼树 B.有向无环图 C. 二叉排序树 D. 栈12以下属于逻辑结构的是( )。A顺序表 B. 哈希表 C.有序表 D. 单链表二、填空题1、_是信息的载体,是对客观事物的符号表示,它能够被计算机识别、存储、加工和处理,_是对能够有效的输人到计算机中并且能够被计算机处理的符号的总称。(数据、数据) 2、数据元素是数据的_,有些情况下也称为元素、结点、顶点、记录等。(基本单位)3、_是数据不可分割的最小单元,是具有独立含义的最小标识单位。例如构成一个数据元素的字段、域、属性等都可称之为_。(数据项、数据项) 4、数据的逻辑结构是指数据之间的_。逻辑结构是从_上
7、描述数据,它与具体存储无关,是独立于计算机的。因此逻辑结构可以看作是从具体问题抽象出来的_。(逻辑关系、逻辑关系、数学模型) 5、数据的_指数据元素及其关系在计算机存储器内的表示。_是逻辑结构在计算机里的实现,也称之为映像。(存储结构、存储结构) 6、数据逻辑结构可以分为四种基本的类型,_结构中的元素除了仅仅只是同属于一个_,不存在什么关系。(集合、集合) 7、数据逻辑结构的四种基本类型中,_中的元素是一种一对一的关系,这种结构的特征是:若结构是非空集,则有且只有一个开始结点和一个终端结点,并且所有结点最多只能有一个直接前驱和一个直接后继。(线性结构) 8、数据逻辑结构的四种基本类型中,_中的
8、元素是一种一对多的关系。(树形结构) 9、图型结构或图状结构是一种_的关系。在这种逻辑结构中,所有结点均可以有多个前驱和多个后继。(多对多) 10、有时也可将树型结构、集合和图型结构称为_,这样数据的逻辑结构就可以分为_和_两大类。(非线性结构、线性结构、非线性机构) 11、_方式是指逻辑上相邻的结点被存储到物理上也相邻的存储单元中。这种存储结构只存储结点的数值,不存储结点之间的关系,结点之间的关系是通过存储单元的相邻关系隐含的表示出来的。(顺序存储) 12、_方式是种存储方法,不要求逻辑上相邻的结点在物理上也相邻,即数据元素可以存储在任意的位置上。(链式存储) 13、_方式是利用结点关键字的
9、值直接计算出该结点存储单元地址,然后将结点按某种方式存人该地址的一种方法。(散列存储或哈希存储) 14、所谓算法(Algorithm)是对特定问题求解步骤的一种描述,它是指令的其中每个指令表示一个或多个操作。算法的五个重要特性是_、_、_、_和_。(有限序列、有穷性、确定性、可行性、输入、输出)15、算法的_性是指算法必须能够在执行有限个步骤之后结束,并且每个步骤都必须在有穷的时间内完成。(有穷性) 16、算法的_性是指算法中的每一个步骤必须是有明确定义的,不允许有模棱两可的解释,也不允许有多义性。并且,在任何条件下,算法只能有惟一的一条执行路径,即只要输人是相同的就只能得到_的输出结果。(确
10、定性、相同) 17、算法的_性又称为算法的能行性,是指算法中描述的操作是可以通过已经实现的基本运算执行有限次来实现。(可行性) 18、判断一个算法的好坏主要以下几个标准:_、_、_、_。(正确性、可读性、健壮性、时间效率和空间效率) 19、算法分析是对一种算法所消耗的计算机资源的估算,其中包括计算机_的长短和_的大小。(运行时间、所占据空间) 20、空间复杂度(SPace ComPlexity)也是度量一个算法好坏的标准,它所描述的是算法在运行过程中所占用_的大小。(存储空间)三、判断题 1顺序存储方式只能用于存储线性结构。() 2数据元素是数据的最小单位。() 3算法的优劣与算法描述语言无关
11、,但与所用计算机有关。() 4健壮的算法不会因非法的输入数据而出现莫名其妙的状态。()5数据的逻辑结构是指各元素之间的逻辑关系,是根据用户需要而建立的。 6数据结构、数据元素、数据项在计算机中的映像分别称为存储结构、结点、数据域。() 7数据的物理结构是指数据在计算机中实际的存储形式。() 8具有存取任一元素的时间相等这一特点的存储结构称为随机存取结构。9算法实际上就是程序,程序也一定是算法。()10. 在顺序存储结构中,有时也存储数据结构中元素之间的关系。()11. 顺序存储方式的优点是存储密度大,且插入、删除运算效率高。()12. 数据结构的基本操作的设置的最重要的准则是,实现应用程序与存
12、储结构的独立。()13. 数据的逻辑结构说明数据元素之间的顺序关系,它依赖于计算机的储存结构。 ()14. 判断一个算法的好坏主要以下几个标准:正确性、有穷性、健壮性和可行性。()15算法的时间复杂度T(n)=O(f(n)表示随问题规模n的增大,算法执行时间的增长率与函数f(n)的增长率相同。()四、综合题 1用大O形式表示下面算法的时间复杂度: for(i=0;im;i十十) for(j=0;jn;j) Aij=i*j; 2写出下面算法的时间复杂度: i0; s=0; while(sn) i+; s+=i; 3写出以下算法的时间复杂度: for(i0; im; i)for(j0 ; jt;
13、j) cij=0;for(i=0;im;i) for(j=o; jt; j+) for(k=0;kn;k) cijaik*bkj;4写出下面算法的时间复杂度:i=1;while(in) i=i*3;5求下面函数中各条语句的频度和算法的时间复杂度:prime(int n) int i2; while (ni)!=0isqrt(n) ) i+; if(isqrt(n) ) printf(”d is a prime number.n”,n); else printf(”d is not a prime number.n”,n);1. 该算法的时间复杂度为:O(mn)。2. 该算法的时间复杂度为:O(
14、)3. 该算法的时间复杂度为:O(mnt)。4. 该算法的时间复杂度为:log3(n)。5. 该算法的时间复杂度为:O()。6将下列函数,按它们在n时的无穷大阶数,从小到大排序。 n, n-n3+7n5, nlogn, 2n/2, n3, logn, n1/2+logn, (3/2)n, ,n!, n2+logn从小到大排列为:logn, n1/2+logn, n, nlogn, n2+logn,n3, n-n3+7n5, 2n/2, (3/2)n, n!,第二章 线性表一、选择题 1在一个长度为n的顺序表中删除第i个元素(0inext=p-next-nextBp-next=p-nextCp=
15、p-next-nextDp=p-next;p-next=p-next-next14在一个单链表中,已知q所指结点是p所指结点的前驱,若在q和p之间插入s所指的结点,则执行( )操作。As-next=p-next;p-next=s;Bq-next=s;s-next=p;Cp-next=s-next;s-next=p;Dp-next=s;s-next=q;15在单链表中附加头结点的目的是为了( )。A保证单链表中至少有一个节点B标识单链表中首结点的位置C方便运算的实现D说明单链表是线性表的链式存储16循环单链表的主要优点是( )。A不再需要头指针了B从表中任意一个结点出发都能扫描到整个链表C已知某
16、个结点的位置后,能够容易找到它的前驱D在进行插入、删除操作时,能更好地保证链表不断开17非空的循环单链表L的尾结点p满足( )。Ap-next=NULLBp=NULLCp-next=LDp=L18在双向循环链表中,在p指针所指向的结点前插入一个指针q所指向的新结点,其修改指针的操作是( )。注:双向链表的结点结构为(prior,data,next)。 供选择的答案:Ap-prior=q; q-next=p; p-prior-next=q; q-prior=q;Bp-prior=q; p-prior-next=q; q-next=p; q-prior=p-prior;Cq-next=p;q-pr
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 习题集 包含 全部 答案 52
限制150内