翻转链表

来源:互联网 发布:游戏王gx结局知乎 编辑:程序博客网 时间:2024/06/06 00:51

描述:翻转一个链表

样例:给出一个链表1->2->3->null,这个翻转后的链表为3->2->1->null挑战 

实现思路:

遍历一遍链表,利用一个辅助指针,存储遍历过程中当前指针指向的下一个元素,然后将当前节点元素的指针反转后,利用已经存储的指针往后面继续遍历。

代码:/**
 * Definition of ListNode
 * 
 * class ListNode {
 * public:
 *     int val;
 *     ListNode *next;
 * 
 *     ListNode(int val) {
 *         this->val = val;
 *         this->next = NULL;
 *     }
 * }
 */
class Solution {
public:
    /**
     * @param head: The first node of linked list.
     * @return: The new head of reversed linked list.
     */
    ListNode *reverse(ListNode *head) {
        // write your code here
    ListNode *prev = NULL;
        while (head != NULL) {
            ListNode *temp = head->next;
            head->next = prev;
            prev = head;
            head = temp;
            
        }
            return prev;
    }


};

做题感想:要在程序当中插入两个指针变量。在遍历的过程当中要先储存当前元素,然后进行当前指针的翻转,最后将已经储存的元素指针向后移。

0 0