递归逆序单链表c语言,递归逆序打印单链表(c实现)

递归逆序打印单链表。交换打印语句和递归调用的顺序,可以实现顺序打印和逆序打印链表。

#include

#include

typedef struct Node {

int data;

struct Node *next;

}Node ;

Node *create_list(int *arr,const int len)

{

if(arr==NULL||len<=0)

{

return NULL;

}

Node *head = (Node*)malloc(sizeof(Node));

head->data = arr[0];

Node *p,*q = head;

for(int i=1;i

{

p = (Node*)malloc(sizeof(Node));

p->data = arr[i];

q->next = p;

q = p;

}

q->next = NULL;

return head;

}

void rprint(Node *head)

{

if(head==NULL)

{

return ;

} else {

rprint(head->next);

printf("%d ",head->data);

}

}

void print(Node *head)

{

Node *p = head;

while(p!=NULL)

{

fprintf(stdout,"%d ",p->data);

p = p->next;

}

}

int main(void)

{

int a[] = {1,2,3,4,5,6,7,8,9};

const int len = sizeof(a)/sizeof(int);

Node *head = create_list(a,len);

print(head);

printf("\n");

rprint(head);

return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值