链表的反转

46 篇文章 0 订阅
34 篇文章 0 订阅

实现一个函数,完成链表的反转

思路:1.循环的方式
建立两个指针,前面的指针的next指向后面的指针,然后分别移动两个指针,循环到链表结尾
2.递归的方式
处理head结点的反转使用head->next->next = head,head->next = NULL,然后递归反转剩余的链表部分

.hpp文件

#ifndef LinkedList_hpp
#define LinkedList_hpp

#include <stdio.h>

#endif /* LinkedList_hpp */

struct LinkNode {
    int val;
    LinkNode *next;
};
 
LinkNode *reverseLink(LinkNode *head);
LinkNode *reverseLinkRecursive(LinkNode *head);

.cpp文件

//
//  LinkedList.cpp
//  CPlusPlusProject
//
//
//
//微信公众号:程序员开发环境


#include "LinkedList.hpp"
#include <iostream>


LinkNode *reverseLink(LinkNode *head){
    //链表判空
    if (head == NULL) {
        return NULL;
    }
    
    //只有一个结点,无需反转
    if (head->next == NULL) {
        return head;
    }
    
    //firstNode为前面的结点,secondNode为后面的结点
    LinkNode *firstNode = head;
    LinkNode *secondNode = NULL;
    while (firstNode->next != NULL) {
        LinkNode *tmp = firstNode->next;
        firstNode->next = secondNode;
        secondNode = firstNode;
        firstNode = tmp;
    }
    firstNode->next = secondNode;
    return firstNode;
}

LinkNode *reverseLinkRecursive(LinkNode *head){
    if (head == NULL) {
        return NULL;
    }
    if (head->next == NULL) {
        return head;
    }
    
    LinkNode *newHead = reverseLink(head->next);
    head->next->next = head;
    head->next = NULL;
    
    return newHead;
}

main函数

#include <iostream>
#include "LinkedList.hpp"

int main(int argc, const char * argv[]) {
    int arr[] = {1, 2, 3, 4, 5, 6};
    LinkNode *head = createLink(arr, 6);
    LinkNode *result = reverseLinkRecursive(head);
    std::cout<<result->val<<std::endl;
    std::cout<<result->next->val<<std::endl;
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值