如果链表里没有结点,那么就是空链表,
需要在头部添加元素,当然一个好的插入算法不需要这样子.
兼容性是所有的程序员必备技能.
如何到达兼容性?
还记得单向链表的添加元素操作?
单向链表添加操作 web link
那里有一个link函数采用的是 兼容性,无论哪一个位置,甚至是 empty LinkList都可以进行插入
如何 做呢?
按照位置插入 : 最小值0 最大值是list.size
插入元素思路:
参数: list,pos,value
判断 pos|<=0吗
用c++ cerr 输出错误信息 pos 过于小
pos> list.size;
可以给机会 将pos修改为list.size;
定义一个用来找到pos的位置的结点
取名为current; 当前结点
一套循环 i<pos
根据i来判断 位置
current=current->next/找到下一个结点
直到==pos 退出循环
就找到了插入的位置
创建新结点 并且初始化数据域和指针域
将当前结点和新结点传入link函数
link函数 调用完毕后
当前链表个数+1
调用完毕!
list.size 一个元素都没有


本文探讨了如何在单向链表中实现兼容性插入,特别是针对空链表的情况。通过定义一个`LinkListInsert`函数,当给定的位置`pos`小于等于0时,会输出错误信息并返回,如果`pos`大于链表长度,则自动调整为末尾插入。使用一个循环找到插入位置,并创建新节点,通过`link`函数完成插入,最后更新链表的大小。此方法确保了在不同位置插入元素的正确性和链表操作的灵活性。
最低0.47元/天 解锁文章
5107

被折叠的 条评论
为什么被折叠?



