C++实现链表反转
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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 | #include "stdio.h" struct ListNode{ int val; ListNode *next; ListNode( int x) : val(x), next(NULL) {} }; class Solution{ public : ListNode* Reverse(ListNode *head){ ListNode *new_head = NULL; while (head){ ListNode *next = head->next; head->next=new_head; new_head=head; head=next; } return new_head; } }; int main(){ ListNode a(1); ListNode b(2); ListNode c(3); ListNode d(4); ListNode e(5); a.next = &b; b.next = &c; c.next = &d; d.next = &e; Solution solve; ListNode *head = &a; printf ( "Before reverse:\n" ); while (head){ printf ( "%d\n" , head->val); head = head->next; } head = solve.Reverse(&a); printf ( "After reverse:\n" ); while (head){ printf ( "%d\n" , head->val); head = head->next; } return 0; } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)