一道数据结构题目求解释。为什么?

下面的叙述不正确的是(B.C)A.线性表在链式存储时,查找第i个元素的时间同i的值成正比B.线性表在链式存储时,查找第i个元素的时间同i的值无关C.线性表在顺序存储时,查... 下面的叙述不正确的是( B.C )
A.线性表在链式存储时,查找第i个元素的时间同i的值成正比
B. 线性表在链式存储时,查找第i个元素的时间同i的值无关
C. 线性表在顺序存储时,查找第i个元素的时间同i 的值成正比
D. 线性表在顺序存储时,查找第i个元素的时间同i的值无关
展开
 我来答
百度网友b0e28cae4
2012-06-09 · TA获得超过4016个赞
知道大有可为答主
回答量:1275
采纳率:85%
帮助的人:620万
展开全部
线性表有两种存储方式:顺序存储(也就是用数组),链式存储(也就是用链表)。
1)当线性表用顺序存储的时候,可以随机访问表里面的任意位置 i 的元素,找到任意位置 i 的元素的复杂度是一样的,和位置无关。

这是因为,顺序存储时,每个元素的存储位置的可以计算出来的,因此也就能根据元素在表中的位置,立即找到。

设第一个元素在内存中的地址为addr,每个元素的大小为 element_size 字节。那么第 i 个元素在内存中的位置为:addr+i*element_size(i>=0)。
可以看出,查找任意位置的元素的时间都是一样的。

2)当线性表用链式存储的时候,访问表里面的任意位置 i 的元素,需要从表里面第一个元素开始,逐次向后查找。

这是因为,链式存储时,第0个元素的存储地址是已知的。表中第i(i>=1)个元素的存储位置,保存在第(i-1)个元素中。
因此要知道第 i 个元素的地址,要先知道第(i-1)个元素的地址;
要知道第(i-1) 个元素的地址,要先知道第(i-2)个元素的地址;
......
要知道第 2 个元素的地址,要先知道第1个元素的地址;
要知道第 1 个元素的地址,要先知道第0个元素的地址;
第0个元素的地址是已知的。
可以看出,在链表中找第 i 个元素,和第 0~(i-1)个元素都有关系。第i个元素一共要找了 i 次。
因此,元素的位置越靠前,也就是 i 越小,能越快的找到。

综上所述,题目中的BC选项是不正确的,相反的,AD选项是正确的。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式