C语言单链表反转

C语言单链表反转

思路部分

  • 假设链表list有4个节点初始状态如下图
    图片一
    反转思路如下

  • 第一次反转时,前面两个节点交换

第一次反转

  • 第二次反转,把一开始的第一个节点连通其前面的节点替换掉其下个节点的位置,然后把被替换的节点移到前面。
    第二次反转
    通过前面的反转,可以找出规律,需要记录的共有三个节点:链表头,当前的第一个节点及一开始的第一个节点,之后按照规律实现需求。

代码部分

链表节点

// 单向链表节点
typedef struct node
{
    int value;                  // 数据域
    struct node *next;          // 指向下个节点
}node;

具体实现(初步实现)


/**
 * 功 能:单链表反转
 * 参数1:链表头
 * 返 回:成功返回0
 * 思 路:链表头从第一个节点指到最后一个节点
 */
err_enum operate_reverse_list(node *list){
    // 链表为空时返回
    if (!list)
    {
        printf("null list\r\n");
        return LIST_NON_EXITSTENT;
    }
    // 只有一个节点或0个节点时不需要反转
    if (!list->next || !list->next->next)
    {
        printf("list need not reverse\r\n");
        return OPERATE_SUCCESS;
    }
    // 链表头
    node *list_head = list;
    // 指向链表当前第一个节点
    node *curr_frist_node = list->next;
    // 指向链表反转后的最后一个节点
    node *new_tail_node = list->next;
    // 开始反转,只要下个节点不为空则继续
    while (new_tail_node->next)
    {
        list_head->next = new_tail_node->next;
        new_tail_node->next = list_head->next->next;
        list_head->next->next = curr_frist_node;
        curr_frist_node = list_head->next;
    }  
    new_tail_node->next = NULL;
    
    return OPERATE_SUCCESS;
}

结尾
写此文章用于记录学习点滴,以后需要时可以回顾。
写得有错误的地方或者可以改进的地方欢迎指出。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,下面是单链表反转的C语言实现代码: ```c #include<stdio.h> #include<stdlib.h> struct ListNode { int val; struct ListNode *next; }; struct ListNode* reverseList(struct ListNode* head) { struct ListNode* prev = NULL; struct ListNode* curr = head; while (curr != NULL) { struct ListNode* nextTemp = curr->next; curr->next = prev; prev = curr; curr = nextTemp; } return prev; } int main() { struct ListNode* head = (struct ListNode*)malloc(sizeof(struct ListNode)); head->val = 1; head->next = (struct ListNode*)malloc(sizeof(struct ListNode)); head->next->val = 2; head->next->next = (struct ListNode*)malloc(sizeof(struct ListNode)); head->next->next->val = 3; head->next->next->next = NULL; struct ListNode* new_head = reverseList(head); while (new_head != NULL) { printf("%d ", new_head->val); new_head = new_head->next; } return 0; } ``` 这段代码中,我们首先定义了一个 `ListNode` 结构体,表示单链表的节点。其中,`val` 表示节点的值,`next` 表示指向下一个节点的指针。接着,我们定义了 `reverseList` 函数,用于反转单链表。在函数中,我们使用了三个指针变量 `prev`、`curr` 和 `nextTemp`,分别表示当前节点的前一个节点、当前节点和当前节点的后一个节点。在循环中,我们不断地将当前节点的 `next` 指针指向前一个节点,然后更新三个指针变量的值,直到当前节点为 `NULL`。最后,我们返回反转后的单链表的头指针 `prev`。在 `main` 函数中,我们构造一个简单链表,并且调用 `reverseList` 函数进行反转,最后输出反转后的单链表的节点值。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值