单链表第三题(反向输出链表值)

3.设L为带头节点的单链表,编写算法实现从尾到头反向输出每个节点的值

代码: 

/*

       有一带头节点的链表,设计一算法从尾到头地输出每一个节点的值

       分析:

               这种类型就有点像是栈的性质,我们可以利用递归来处理,出口便是尾元素

*/

#define_CRT_SECURE_NO_WARNINGS

#include<stdio.h>

#include<stdlib.h>

#include"linkStruct.h"//通过自创建头文件引入结构体,ctrl+鼠标左键点击即可查看

void    reverseOutput(Link   *p){

           if(p==NULL)     return;

           else{

                  reverseOutput(P->next);

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

                 }

}

int   main(){

            int     n,data;

            //创建链表

           Link*   head=(Link*)malloc(sizeof(link));

           Link*   createLink(int);

           head=createLink(0);

            reverseOutput(head->next);

            return      0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现带头结点的单链表反向输出每个结点的,可以使用递归或者栈来实现。下面是一个使用递归的示例C语言代码: ```c #include <stdio.h> #include <stdlib.h> // 定义链表结点结构 typedef struct Node { int data; struct Node* next; } Node; // 创建一个带头结点的链表 Node* createLinkedList() { Node* head = (Node*)malloc(sizeof(Node)); head->next = NULL; return head; } // 向链表中插入新结点 void insertNode(Node* head, int value) { Node* newNode = (Node*)malloc(sizeof(Node)); newNode->data = value; newNode->next = head->next; head->next = newNode; } // 递归反向输出每个结点的 void reversePrint(Node* node) { if (node == NULL) { return; } reversePrint(node->next); printf("%d ", node->data); } // 释放链表内存 void freeLinkedList(Node* head) { Node* curr = head; while (curr != NULL) { Node* temp = curr; curr = curr->next; free(temp); } } int main() { Node* head = createLinkedList(); // 插入测试数据 insertNode(head, 3); insertNode(head, 6); insertNode(head, 2); insertNode(head, 8); insertNode(head, 9); printf("反向输出每个结点的:"); reversePrint(head->next); printf("\n"); freeLinkedList(head); return 0; } ``` 在这个示例中,我们首先创建了一个带头结点的链表,并向其中插入一些测试数据。然后,我们使用`reversePrint`函数递归地反向输出每个结点的。最后,我们释放链表的内存。 希望这个示例能够帮助到你!如果你还有其他问,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值