鱼C论坛

 找回密码
 立即注册
查看: 4232|回复: 1

[已解决]刚学的链表,求个示范

[复制链接]
发表于 2022-12-23 20:52:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
1、输入字符a至f,按输入字符的顺序建立一个字符结点(每个结点存储一个字符)的单向链表,输出该链表中的字符,并释放链表结点所占用的空间。
最佳答案
2022-12-23 21:17:59
  1. #include <stdio.h>
  2. #include <malloc.h>

  3. typedef struct Node {
  4.         char data;
  5.         struct Node* next;
  6. }Node;

  7. void show(Node* head) {
  8.         if (!(head)) {
  9.                 return;
  10.         }
  11.         show(head->next);
  12.         printf("%c ", head->data);
  13. }

  14. void freeAll(Node** head) {
  15.         Node* p;
  16.         while (*head) {
  17.                 p = *head;
  18.                 *head = (*head)->next;
  19.                 free(p);
  20.         }
  21.         free(*head);
  22. }

  23. int main(void) {
  24.         Node* head, * tail = head = NULL;
  25.         char string[7] = "abcdef"; // 字符 a 至 f
  26.         int i = 0;

  27.         // 按输入字符的顺序建立一个字符结点(每个结点存储一个字符)的单向链表
  28.         while (string[i]) {
  29.                 tail = head;
  30.                 head = (Node*)malloc(sizeof(Node));
  31.                 if (head) {
  32.                         head->data = string[i++];
  33.                         head->next = tail;
  34.                 }
  35.         }

  36.         // 输出该链表中的字符
  37.         show(head);

  38.         // 释放链表结点所占用的空间
  39.         freeAll(&head);
  40.         return 0;
  41. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-12-23 21:17:59 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>
  2. #include <malloc.h>

  3. typedef struct Node {
  4.         char data;
  5.         struct Node* next;
  6. }Node;

  7. void show(Node* head) {
  8.         if (!(head)) {
  9.                 return;
  10.         }
  11.         show(head->next);
  12.         printf("%c ", head->data);
  13. }

  14. void freeAll(Node** head) {
  15.         Node* p;
  16.         while (*head) {
  17.                 p = *head;
  18.                 *head = (*head)->next;
  19.                 free(p);
  20.         }
  21.         free(*head);
  22. }

  23. int main(void) {
  24.         Node* head, * tail = head = NULL;
  25.         char string[7] = "abcdef"; // 字符 a 至 f
  26.         int i = 0;

  27.         // 按输入字符的顺序建立一个字符结点(每个结点存储一个字符)的单向链表
  28.         while (string[i]) {
  29.                 tail = head;
  30.                 head = (Node*)malloc(sizeof(Node));
  31.                 if (head) {
  32.                         head->data = string[i++];
  33.                         head->next = tail;
  34.                 }
  35.         }

  36.         // 输出该链表中的字符
  37.         show(head);

  38.         // 释放链表结点所占用的空间
  39.         freeAll(&head);
  40.         return 0;
  41. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-23 00:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表