鱼C论坛

 找回密码
 立即注册
查看: 3632|回复: 4

[已解决]线性表元素插入算法必须反向遍历?是有巧思吗?

[复制链接]
发表于 2020-11-26 09:47:27 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
B站:【C语言描述】《数据结构和算法》(小甲鱼)
问题定位:P8线性表3.

插入算法的思路:
如果插入位置不合理,抛出异常;
如果线性表长度大于等于数组长度,则抛出异常或动态增加容量;
从最后一个元素开始向前遍历到第i个位置,分别将它们都向后移动一个位置;
将要插入元素填入位置i处,表长加1。

问题:
为什么必须“从最后一个元素开始向前遍历到第i个位置”?从第一个往后遍历不可以吗?

最后,支持甲鱼!支持论坛!
最佳答案
2020-11-28 06:40:40
麦麦先森 发表于 2020-11-27 14:08
我没明白,为什么会覆盖?如果从前向后遍历时,遍历到第i个位置时,先将后面的所有元素都向后移动一个位 ...

我明白了,线性表可以索引查找位置,不需要遍历找到那个位置
上面说的遍历是移动元素而不是找位置
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-26 11:37:47 | 显示全部楼层
这是插入元素啊,如果从前往后遍历的话,前面的会覆盖掉后面的
如插入的元素是1,则从这个位置后的所有元素都会为1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-27 14:08:58 | 显示全部楼层
巴巴鲁 发表于 2020-11-26 11:37
这是插入元素啊,如果从前往后遍历的话,前面的会覆盖掉后面的
如插入的元素是1,则从这个位置后的所有元 ...

我没明白,为什么会覆盖?如果从前向后遍历时,遍历到第i个位置时,先将后面的所有元素都向后移动一个位置,然后再插入,不应该是等效的吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-28 06:40:40 | 显示全部楼层    本楼为最佳答案   
麦麦先森 发表于 2020-11-27 14:08
我没明白,为什么会覆盖?如果从前向后遍历时,遍历到第i个位置时,先将后面的所有元素都向后移动一个位 ...

我明白了,线性表可以索引查找位置,不需要遍历找到那个位置
上面说的遍历是移动元素而不是找位置
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-2 10:29:54 | 显示全部楼层
巴巴鲁 发表于 2020-11-28 06:40
我明白了,线性表可以索引查找位置,不需要遍历找到那个位置
上面说的遍历是移动元素而不是找位置

这样理解的话,就可以说通了,谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-7-5 00:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表