1.标题
707. 计划链表 - 力扣(LeetCode)
你可以选择使用单链表大概双链表,计划并实现自己的链表。
单链表中的节点应该具备两个属性:val 和 next 。val 是当前节点的值,next 是指向下一个节点的指针/引用。
如果是双向链表,则还需要属性 prev 以指示链表中的上一个节点。假设链表中的所有节点下标从 0 开始。
实现 MyLinkedList 类:
- MyLinkedList() 初始化 MyLinkedList 对象。
- int get(int index) 获取链表中下标为 index 的节点的值。如果下标无效,则返回 -1 。
- void addAtHead(int val) 将一个值为 val 的节点插入到链表中第一个元素之前。在插入完成后,新节点会成为链表的第一个节点。
- void addAtTail(int val) 将一个值为 val 的节点追加到链表中作为链表的末了一个元素。
- void addAtIndex(int index, int val) 将一个值为 val 的节点插入到链表中下标为 index 的节点之前。如果 index 等于链表的长度,那么该节点会被追加到链表的末端。如果 index 比长度更大,该节点将 不会插入 到链表中。
- void deleteAtIndex(int index) 如果下标有效,则删除链表中下标为 index 的节点。
示例:
- <strong>输入</strong>
- ["MyLinkedList", "addAtHead", "addAtTail", "addAtIndex", "get", "deleteAtIndex", "get"]
- [[], [1], [3], [1, 2], [1], [1], [1]]
- <strong>输出</strong>
- [null, null, null, null, 2, null, 3]
- <strong>解释</strong>
- MyLinkedList myLinkedList = new MyLinkedList();
- myLinkedList.addAtHead(1);
- myLinkedList.addAtTail(3);
- myLinkedList.addAtIndex(1, 2); // 链表变为 1->2->3
- myLinkedList.get(1); // 返回 2
- myLinkedList.deleteAtIndex(1); // 现在,链表变为 1->3
- myLinkedList.get(1); // 返回 3
复制代码
提示:
- 0 <= index, val <= 1000
- 请不要使用内置的 LinkedList 库。
- 调用 get、addAtHead、addAtTail、addAtIndex 和 deleteAtIndex 的次数不凌驾 2000 。
2.代码
直接套用+修改C26.【C++ Cont】动态内存管理和面向对象的方式实现链文章的代码
注意点:
1.每一种环境返回前思索需不需要length++大概length--
★以SLTPopBack为例,有两个地方需要length--!!!(此处debug 1h 才看出来标题= =)
2.几个特殊环境的处理
get:链表长为0大概index>=length的,一律返回-1
addAtIndex:index>length不作处理,index==length按题意理解为尾插,index==0为头插
deleteAtIndex:链表长为0大概index>=length的,一律不处理;index == length - 1尾删;index == 0头删
3.提交效果
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |