分析:
有一条链,按照一般思路,那就直接将最后一个元素的值和第一个元素的值对调就可以了。这个方法适合于数组。例如:颠倒数组。但是在链表操作的过程中我们发现我们并不能直接找到链表的尾部,如果要找,需要一次次遍历,这样,逆置一条链表将花费巨大的时间(O(n^2))。
不过,我们可以考虑将链表的每个节点拆下来,然后用头插入的方法重新连接,这样就比较高效了。
#include<iostream>
using namespace std;
struct node {
int data;
node* next;
};
//循环创建带有表头的链表:
node* create(int n) {
node* head, * tail, * p;
head = tail = new node;
head->data = 0;
while (n--) {
p = new node;
cin >> p->data;
p->next = NULL;
tail->next = p;
tail = p;
}
return head;
}
//逆置带头结点的链表元素,但是原来的头结点仍然保持在最前面
node* Inversion(node*head) {
node*p,*q;
p=q=(head->next)->next;
node *head1=head->next;
head1->next=0;
while(p){
q=q->next;//为的是不让节点的数据走丢
p->next=head1;
head1=p;
p=q;
}
head->next=head1;
return head;
}
int main() {
int n = 3;
node* p;
p = create(3);
p =Inversion(p) ;
p = p->next;//跳过表头指针
while (p) {
cout << p->data << " ";
p = p->next;
}
return 0;
}
运行结果:

本文介绍了一种高效的链表逆置算法,通过头插入法重新连接链表节点,避免了传统方法中查找链表尾部的高时间复杂度问题。文章提供了C++实现代码,并展示了逆置后的链表元素。
1795

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



