逆转线性链表的算法c语言,pta-数据结构与算法题目集(中文)-4-1-单链表逆转...

本题要求实现一个函数,将给定的单链表逆转。

函数接口定义:

List Reverse( List L );

其中List结构定义如下:

typedef struct Node *PtrToNode;

struct Node {

ElementType Data; /* 存储结点数据 */

PtrToNode Next; /* 指向下一个结点的指针 */

};

typedef PtrToNode List; /* 定义单链表类型 */

L是给定单链表,函数Reverse要返回被逆转后的链表。

裁判测试程序样例:

#include

#include

typedef int ElementType;

typedef struct Node *PtrToNode;

struct Node {

ElementType Data;

PtrToNode Next;

};

typedef PtrToNode List;

List Read(); /* 细节在此不表 */

void Print( List L ); /* 细节在此不表 */

List Reverse( List L );

int main()

{

List L1, L2;

L1 = Read();

L2 = Reverse(L1);

Print(L1);

Print(L2);

return 0;

}

/* 你的代码将被嵌在这里 */

输入样例:

5

1 3 4 5 2

输出样例:

1

2 5 4 3 1

code:

#include

#include

typedef int ElementType;

typedef struct Node *PtrToNode;

struct Node {

ElementType Data;

PtrToNode Next;

};

typedef PtrToNode List;

List Read(); /* 细节在此不表 */

void Print( List L ); /* 细节在此不表 */

List Reverse( List L );

int main()

{

List L1, L2;

L1 = Read();

L2 = Reverse(L1);

Print(L1);

Print(L2);

return 0;

}

List Read(){

int len = 0;

int num = 0;

PtrToNode list = NULL;

PtrToNode last = NULL;

scanf( "%d",&len );

if( 0 == len ){

return NULL;

}

scanf( "%d",&num );

list = ( PtrToNode )malloc( sizeof( struct Node ) );

list->Data = num;

list->Next = NULL;

last = list;

len--;

while( len > 0 ){

scanf( "%d",&num );

PtrToNode node = ( PtrToNode )malloc( sizeof( struct Node ) );

node->Data = num;

node->Next = NULL;

last->Next = node;

last = node;

len--;

}

return list;

}

void Print( List L ){

if( NULL == L ){

return ;

}

PtrToNode last = L;

while( NULL != last ){

printf( "%d ",last->Data );

last = last->Next;

}

putchar( '\n' );

}

List Reverse( List L ){

if( NULL == L ){

return NULL;

}

PtrToNode listre = NULL;

PtrToNode t = L->Next;

if( NULL == t ){

listre = L;

return listre;

}

L->Next = t->Next;

listre = t;

t->Next = L;

while( NULL != L->Next ){

t = L->Next;

L->Next = t->Next;

t->Next = listre;

listre = t;

}

return listre;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值