在线计算网 · 发布于 2025-03-02 16:46:03 · 已经有7人使用
在面向对象C++程序设计中,链表是一种重要的数据结构,掌握其插入操作和有序链表的建立对于提升编程技能至关重要。本文将详细讲解链表的插入及有序链表的建立方法。
链表是一种动态数据结构,由一系列节点组成,每个节点包含数据和指向下一个节点的指针。链表分为单链表、双链表和循环链表等。
struct ListNode {
int val;
ListNode* next;
ListNode(int x) : val(x), next(nullptr) {}
};
链表的插入操作分为头插法、尾插法和中间插入三种情况。
void insertAtHead(ListNode*& head, int value) {
ListNode* newNode = new ListNode(value);
newNode->next = head;
head = newNode;
}
void insertAtTail(ListNode*& head, int value) {
ListNode* newNode = new ListNode(value);
if (head == nullptr) {
head = newNode;
return;
}
ListNode* temp = head;
while (temp->next != nullptr) {
temp = temp->next;
}
temp->next = newNode;
}
void insertAtMiddle(ListNode*& head, int value, int position) {
ListNode* newNode = new ListNode(value);
if (position == 0) {
newNode->next = head;
head = newNode;
return;
}
ListNode* temp = head;
for (int i = 0; temp != nullptr && i < position - 1; i++) {
temp = temp->next;
}
if (temp == nullptr) return;
newNode->next = temp->next;
temp->next = newNode;
}
有序链表是指链表中的节点按某种顺序排列。建立有序链表的关键在于插入节点时保持顺序。
void insertInOrder(ListNode*& head, int value) {
ListNode* newNode = new ListNode(value);
if (head == nullptr || head->val >= value) {
newNode->next = head;
head = newNode;
return;
}
ListNode* temp = head;
while (temp->next != nullptr && temp->next->val < value) {
temp = temp->next;
}
newNode->next = temp->next;
temp->next = newNode;
}
以下是一个完整的示例代码,展示了如何插入节点和建立有序链表。
#include <iostream>
using namespace std;
struct ListNode {
int val;
ListNode* next;
ListNode(int x) : val(x), next(nullptr) {}
};
void insertAtHead(ListNode*& head, int value) {
ListNode* newNode = new ListNode(value);
newNode->next = head;
head = newNode;
}
void insertAtTail(ListNode*& head, int value) {
ListNode* newNode = new ListNode(value);
if (head == nullptr) {
head = newNode;
return;
}
ListNode* temp = head;
while (temp->next != nullptr) {
temp = temp->next;
}
temp->next = newNode;
}
void insertInOrder(ListNode*& head, int value) {
ListNode* newNode = new ListNode(value);
if (head == nullptr || head->val >= value) {
newNode->next = head;
head = newNode;
return;
}
ListNode* temp = head;
while (temp->next != nullptr && temp->next->val < value) {
temp = temp->next;
}
newNode->next = temp->next;
temp->next = newNode;
}
void printList(ListNode* head) {
while (head != nullptr) {
cout << head->val << " -> ";
head = head->next;
}
cout << "nullptr" << endl;
}
int main() {
ListNode* head = nullptr;
insertInOrder(head, 10);
insertInOrder(head, 5);
insertInOrder(head, 20);
printList(head);
return 0;
}
通过本文的学习,读者应掌握了链表的插入操作和有序链表的建立方法。这些知识对于解决实际编程问题具有重要意义。希望读者能够通过实践进一步巩固所学内容。
《C++ Primer》
《数据结构与算法分析》
1485次Python Web开发教程:掌握表单字段类型,提升编程实战能力
1441次精影RX 5500 XT 8G电源推荐:如何选择合适的瓦数
1391次JMeter性能测试教程:详解HTTP信息头管理器
1207次技嘉GeForce GTX 1660 SUPER MINI ITX OC 6G参数详解:小巧强芯,游戏利器
1174次深入理解Go Web开发:URI与URL的区别与应用
1139次JavaScript函数参数详解:掌握前端编程核心技巧
1020次七彩虹战斧RTX 3060 Ti豪华版LHR显卡参数详解:性能强悍,性价比之王
590360次四川话女声语音合成助手
104991次生辰八字计算器
73208次4x4四阶矩阵行列式计算器
67027次情侣恋爱日期天数计算器
62973次各种金属材料重量在线计算器
54996次分贝在线计算器
51473次任意N次方计算器
49798次经纬度分秒格式在线转换为十进制
49596次卡方检验P值在线计算器
43010次三角函数计算器