6 Reverse Linked List

分数 20

作者 陈越

单位 浙江大学

Write a nonrecursive procedure to reverse a singly linked list in O(N) time using constant extra space.

Format of functions:

cs 复制代码
List Reverse( List L );

where List is defined as the following:

cs 复制代码
typedef struct Node *PtrToNode;
typedef PtrToNode List;
typedef PtrToNode Position;
struct Node {
    ElementType Element;
    Position Next;
};

The function Reverse is supposed to return the reverse linked list of L, with a dummy header.

Sample program of judge:

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

typedef int ElementType;
typedef struct Node *PtrToNode;
typedef PtrToNode List;
typedef PtrToNode Position;
struct Node {
    ElementType Element;
    Position Next;
};

List Read(); /* details omitted */
void Print( List L ); /* details omitted */
List Reverse( List L );

int main()
{
    List L1, L2;
    L1 = Read();
    L2 = Reverse(L1);
    Print(L1);
    Print(L2);
    return 0;
}

/* Your function will be put here */

Sample Input:

复制代码
5
1 3 4 5 2

Sample Output:

复制代码
2 5 4 3 1
2 5 4 3 1

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

解题思路如下:

1.首先判断该单链表是否为空链表若为空则直接返回改链表

2.若不为空,则创建两个指针beg和end,一个指向原单链表的第一个数据结点,一个指向第一个数据结点的下一个结点。

3.接下来进行四个步骤的循环:

第一步:连(防止断链找不到下一个结点),将beg的Next域指针指向end的Next域指针所指向的结点,那么beg的Next域指向end结点的链将断掉。

第二步:调,将end的Next域指向L的头结点所指向的结点。

第三步:接,将新的第一个数据节点的地址保存在原来的头结点中

第四步:移,将end指针移动到beg的Next指针域指向的结点

具体代码如下:

cs 复制代码
List Reverse(List L) {
    if(L == NULL || L ->Next == NULL){
        return L;//如果链表为空则直接返回该链表
    }
    List beg,end;//创建两个指针
    beg = L->Next;//一个指向单链表的头结点
    end = beg->Next;//一个指向头结点里Next域所指向的结点
    while(end != NULL){//循环条件为end不为空
        beg ->Next = end->Next;//第一步链接
        end->Next = L->Next;//第二步断链、调转
        L->Next = end;//第三步改变链接新的数据结点
        end = beg->Next;//第四步移动指针到新的结点
    }
    return L;
}
相关推荐
爱编码的小八嘎3 分钟前
C语言完美演绎8-4
c语言
桌面运维家14 分钟前
IDV云桌面vDisk机房部署方案模板特性解析
java·开发语言·devops
CS_Zero16 分钟前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵16 分钟前
聚酯切片DSC热分析应用报告
人工智能·算法
飞翔的SA18 分钟前
从6.75%到100%!大模型Function Calling终极方案:Harness工程如何驯服
开发语言·ai·llm·harness
@BangBang23 分钟前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先
耿雨飞31 分钟前
Python 后端开发技术博客专栏 | 第 09 篇 GIL 深度解析与并发编程实战 -- 多线程、多进程、协程的选型
开发语言·python
Stark-C32 分钟前
NAS音乐必备神器,全平台音乐收割机!极空间部署『Go Music DL』
开发语言·后端·golang
Ulyanov36 分钟前
像素迷宫:路径规划算法的可视化与实战
大数据·开发语言·python·算法
Mr_pyx44 分钟前
【LeetCode Hot 100】 除自身以外数组的乘积(238题)多解法详解
算法·leetcode·职场和发展