llllmz

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

707. 设计链表

心要细,这题才能作对。

class MyLinkedList {
public:
MyLinkedList()
:_size(0), _head(new listedNode(0))
{}
int get(int index) {
if(index < 0 || index >= _size) return -1;
listedNode* cur = _head;
for(int i = 0; i <= index; ++i){
cur = cur->next;
}
return cur->value;
}
void addAtHead(int val) {
addAtIndex(0, val);
}
void addAtTail(int val) {
addAtIndex(_size, val);
}
void addAtIndex(int index, int val) {
if(index < 0 || index > _size) return;
listedNode* temp = new listedNode(val);
listedNode* preNode = _head;
for(int i = 0; i < index; ++i) preNode = preNode->next;
temp->next = preNode->next;
preNode->next = temp;
++_size;
}
void deleteAtIndex(int index) {
if(index < 0 || index >= _size || _size == 0) return;
--_size;
listedNode* preNode = _head;
for(int i = 0; i < index; ++i) preNode = preNode->next;
listedNode* delNode = preNode->next;
preNode->next= preNode->next->next;
delete delNode;
}
private:
struct listedNode{
int value;
listedNode* next;
listedNode(int val)
:value(val), next(nullptr)
{}
};
int _size;
listedNode* _head;
};

posted on   神奇的萝卜丝  阅读(5)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示