![数据结构(C语言实现)](https://wfqqreader-1252317822.image.myqcloud.com/cover/699/43806699/b_43806699.jpg)
习题
一、选择题
1.研究数据结构就是研究( )。
A.数据的逻辑结构
B.数据的存储结构
C.数据的逻辑结构和存储结构
D.数据的逻辑结构、存储结构及其基本操作
2.计算机中的算法必须具备输入、输出、( )5个特性。
A.可行性、可移植性和可扩充性
B.可行性、有穷性和确定性
C.确定性、有穷性和稳定性
D.易读性、稳定性和确定性
3.算法分析是对一个算法的( )进行评价。
A.空间复杂度和时间复杂度
B.正确性和简单性
C.可读性和文档性
D.数据复杂性和程序复杂性
4.算法是一种( )。
A.计算机程序
B.解决问题的计算方法
C.排序算法
D.解决问题的有限运算序列
5.设n是描述问题规模的非负整数,下面程序段的时间复杂度为( )。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/24_01.jpg?sign=1738931460-5wCEKg6RbwRDOrTyl7zUXL4X957j6CrD-0-d698fe953506a79869d8fe11d469a397)
A.O(log2n)
B.O(n)
C.O(nlog2n)
D.O(n2)
6.下面程序段的时间复杂度为( )。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/24_02.jpg?sign=1738931460-k3CxN00YhcSj7CQgVRcHe8aVTt4Nh6YH-0-86ee3a5729afddb6100c410d876fce1a)
A.O(n)
B.O(3n)
C.O(log3n)
D.O(n3)
7.下面程序段的时间复杂度是( )。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/24_03.jpg?sign=1738931460-mXYxbSzMgySUTeFphcsFeGRWCdFZ5PVF-0-112130eefbfd6d43e85247864fbe68cb)
A.O(n)
B.
C.O(log2n)
D.O(n3)
8.求整数n(n≥0)阶乘的算法如下,其时间复杂度为( )。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/24_05.jpg?sign=1738931460-d3oMZIRyC0iY3l8QUb4WYimEuPwVMpQI-0-e2f9a8173333e48edf983416ef16ee13)
A.O(log2n)
B.O(n)
C.O(nlog2n)
D.O(n2)
9.下面程序段的时间复杂度为( )。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/24_06.jpg?sign=1738931460-bS21hVOg0LeF0zEFf7zRzRVCk7mTy4oT-0-e745a5d31373d08ad7afc3dc1fb1caac)
A.O(n)
B.
C.O(1)
D.O(n2)
10.下面算法的时间复杂度为( )。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/24_08.jpg?sign=1738931460-SjgqikcMOXUW2QqK1I1rE7C7WxipjbQf-0-e835a20190437b58266b6a8b0726ddc7)
A.O(1)
B.O(n)
C.O(n2)
D.O(n!)
11.下面算法的时间复杂度为( )。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/25_01.jpg?sign=1738931460-hly905ReCpsyIDykaFPE8nUodEVv28rZ-0-5c34e4674674dad4b2f3d9c505e8dc95)
A.O(n)
B.O(nlog2n)
C.
D.
二、填空题
1.通常从四个方面评价算法的质量:_________、_________、_________和_________。
2.数据的逻辑结构指数据对象之间的相互关系,有_________、_________、_________和_________四种。
3.数据结构是一门研究非数值计算的程序设计问题中计算机的数据元素以及它们之间的_________和运算等的学科。
4.下面程序段中语句s的执行次数为_________。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/25_04.jpg?sign=1738931460-2t0WbRqvFjvUH3eRuiaOOe04azU9lNYa-0-9b8371a315e0a998427668006d30c29e)
5.下面程序段的时间复杂度是_________。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/25_05.jpg?sign=1738931460-hazDaMZAFK7lNDVeoXtuyrtiW0I9iXgk-0-a0de83232bfe0bb636088ac4cadd7154)
A.O(m2)
B.O(n2)
C.O(n*m)
D.O(m+n)
三、算法分析题
1.一个算法所需时间由下面的递归方程表示,试求出该算法的时间复杂度(以大O形式表示)。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/25_06.jpg?sign=1738931460-hnMXJUiqUqN6043mOmgDeIf4qgHKT3Mp-0-fbdda5cbecce09369b97973173211b34)
其中,n是问题的规模,为简单起见,设n为2的整数幂。
2.调用下面的c函数f(n),回答以下问题:
(1)试指出f(n)值的大小,并写出f(n)值的推导过程。
(2)设n=5,试指出f(5)值的大小和执行f(5)时的输出结果。
![](https://epubservercos.yuewen.com/2EFA35/23083815801896206/epubprivate/OEBPS/Images/25_07.jpg?sign=1738931460-EpsoUorT7EGTBPy015SyN3QMHFQqyTxn-0-0efe25b03d7a07f970b0f07ca1216a7e)