ZBLOG

链表头插实现排序

在链表中使用头插法进行排序的基本思路是逐个将元素插入到已排序的部分,始终保持链表的有序状态。以下是一个简单的示例,展示了如何实现这一过程。

我们以单链表为例,并使用 C++ 语言进行实现。下面是具体步骤和代码:

  1. 定义节点结构:定义一个链表节点的结构体。
  2. 创建插入函数:实现头插法插入节点。
  3. 排序函数:逐步将未排序的节点插入到已排序链表中的适当位置。

以下是代码示例:

#include <iostream>

struct Node {
    int data;
    Node* next;

    Node(int val) : data(val), next(nullptr) {}
};

class LinkedList {
public:
    Node* head;

    LinkedList() : head(nullptr) {}

    // 头插法
    void insertAtHead(int val) {
        Node* newNode = new Node(val);
        newNode->next = head;
        head = newNode;
    }

    // 排序函数(使用插入排序)
    void sortedInsert(Node* newNode) {
        if (head == nullptr || head->data >= newNode->data) {
            newNode->next = head;
            head = newNode;
        } else {
            Node* current = head;
            while (current->next != nullptr && current->next->data < newNode->data) {
                current = current->next;
            }
            newNode->next = current->next;
            current->next = newNode;
        }
    }

    // 排序整个链表
    void sort() {
        Node* sorted = nullptr; // 新的已排序链表

        Node* current = head; 
        while (current != nullptr) {
            Node* nextNode = current->next; // 保存下一个要处理的节点
            sortedInsert(current);           // 插入到新的已排序链表中
            current = nextNode;             // 移动到下一个节点
        }
        
        head = sorted; // 更新原始头指针为新排好序的列表头
    }

    // 打印链表
    void printList() const {
        Node* temp = head;
        while (temp != nullptr) {
            std::cout << temp->data << " -> ";
            temp = temp->next;
        }
        std::cout << "nullptr" << std::endl;
    }
};

int main() {
    LinkedList list;

    list.insertAtHead(5);
    list.insertAtHead(3);
    list.insertAtHead(8);
    list.insertAtHead(1);
    
    std::cout << "Original List: ";
    list.printList();

  	list.sort(); 
    
  	std::cout << "Sorted List: ";
  	list.printList();
  
  	return 0;
}

说明:

  1. insertAtHead 函数用于在链表头部插入新节点。
  2. sortedInsert 函数将当前节点按照大小顺序插入到已排序部分。
  3. sort 函数迭代处理原始链表,将每个节点通过 sortedInsert 插入到新的已排好序的链接中。

使用方法:

你可以在 main 函数中测试上述代码,通过调用不同的数据进行测试。在这个示例中,我们先创建一些无序数据,然后对其进行头插法排序,并打印结果。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=18879

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?