当前位置: 首页 > news >正文

C语言基础(二十)

链表是一种常见的数据结构,通常用来存储一系列元素,每个元素由一个节点来表示。在链表中,每个节点包含两部分:数据元素本身和指向下一个节点的指针。这种结构使得链表中的元素在内存中不是连续存储的,而是通过指针连接起来。链表可以分为单向链表和双向链表两种类型。在单向链表中,每个节点只有一个指向下一个节点的指针;而在双向链表中,每个节点有一个指向前一个节点的指针和一个指向后一个节点的指针。

测试代码1:

#include "date.h"
#include <stdio.h>
#include <stdlib.h>// 定义链表节点结构
typedef struct ListNode {int val;struct ListNode* next;
} ListNode;// 创建新节点
ListNode* createNode(int val) {ListNode* newNode = (ListNode*)malloc(sizeof(ListNode));if (newNode == NULL) {printf("Memory allocation failed!n");exit(1);}newNode->val = val;newNode->next = NULL;return newNode;
}// 在链表末尾添加节点
void appendNode(ListNode** head, int val) {ListNode* newNode = createNode(val);if (*head == NULL) {*head = newNode;} else {ListNode* temp = *head;while (temp->next != NULL) {temp = temp->next;}temp->next = newNode;}
}
// 打印链表节点地址的函数  
void printListAddress(ListNode* head) {  ListNode* current = head;  while (current != NULL) {  printf("Node value: %d, Address: %p\n", current->val, (void*)current);  current = current->next;  }  
}  // 遍历链表并打印每个节点的值
void printList(ListNode* head) {ListNode* temp = head;while (temp != NULL) {printf("%d -> ", temp->val);temp = temp->next;}printf("NULL\n");
}// 主函数
int main() {int time = getTime();ListNode* head = NULL; // 初始化链表为空// 向链表添加节点appendNode(&head, 1);appendNode(&head, 5);appendNode(&head, 0);appendNode(&head, 9);appendNode(&head, 3);appendNode(&head, 8);// 遍历并打印链表printList(head);// 打印链表节点地址printListAddress(head);// 释放链表内存ListNode* current = head;ListNode* next;while (current != NULL) {next = current->next;free(current);current = next;}head = NULL;  // 将头指针置为空,防止野指针访问return 0;
}

运行结果如下:

测试代码2:

#include "date.h"
#include <stdio.h>  
#include <stdlib.h>  // 定义链表节点结构体  
typedef struct ListNode {  int val;            // 链表节点值 struct ListNode* next; // 指针域,指向下一个节点  
} ListNode;  // 创建新节点  
ListNode* createNode(int val) {  ListNode* newNode = (ListNode*)malloc(sizeof(ListNode));  if (newNode == NULL) {  printf("Memory allocation failed!\n");  exit(1); // 终止程序  }  newNode->val = val;  newNode->next = NULL;  return newNode;  
}  // 遍历链表并打印信息  
void printList(ListNode* head) {  ListNode* current = head;  while (current != NULL) {  printf("Node Address: %p, Value: %d, Next Node Address: %p\n",  (void*)current, current->val, (void*)(current->next));  current = current->next;  }  
}  // 主函数  
int main() { int time = getTime(); // 创建链表节点  // 创建链表节点  ListNode* head = createNode(1); // 头结点  ListNode* current = head; // 用于遍历链表的指针  // 将剩余节点添加到链表中  current->next = createNode(2);  current = current->next;  current->next = createNode(3);  current = current->next;  current->next = createNode(4);  current = current->next;  current->next = createNode(5);  // 打印链表信息  printf("Linked List:\n");  printList(head);  // 释放链表内存ListNode* temp;  while (head != NULL) {  temp = head;  head = head->next;  free(temp);  }  head = NULL;  // 将头指针置为空,防止野指针访问return 0;  
}

运行结果如下:

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • OpenCV几何图像变换(9)仿射变换函数warpAffine()的使用
  • 【iOS安全】iPhone8 iOS14.4.2 越狱教程
  • ubuntu22.04安装redis
  • 免费分享:2000-2020年MODIS中国积雪物候数据集(附下载办法)
  • [论文阅读] mobile aloha实验部分
  • 一. 初始 Spring Boot
  • 充电桩定期检测是如何实现的
  • 【银河麒麟】银河麒麟桌面操作系统 V10 (SP1) 2403 版(ARM64)安装 Windows 软件(Wine)
  • 泰山派小手机---ubuntu 环境的搭建
  • Kubernetes的Taint污点和Toleration容忍
  • Spring Boot如何压缩Json并写入redis?
  • Window Performance API
  • 苹果机器人计划:能否成为智能家居的破局者?
  • MyBatis查询 ▎修改 ▎删除
  • postman请求设置
  • [笔记] php常见简单功能及函数
  • 【干货分享】SpringCloud微服务架构分布式组件如何共享session对象
  • 5、React组件事件详解
  • CSS居中完全指南——构建CSS居中决策树
  • Docker容器管理
  • If…else
  • JAVA并发编程--1.基础概念
  • laravel5.5 视图共享数据
  • mysql外键的使用
  • PHP 7 修改了什么呢 -- 2
  • Quartz实现数据同步 | 从0开始构建SpringCloud微服务(3)
  • socket.io+express实现聊天室的思考(三)
  • Travix是如何部署应用程序到Kubernetes上的
  • V4L2视频输入框架概述
  • 大数据与云计算学习:数据分析(二)
  • 反思总结然后整装待发
  • 个人博客开发系列:评论功能之GitHub账号OAuth授权
  • 前端性能优化——回流与重绘
  • 前端学习笔记之观察者模式
  • 让你成为前端,后端或全栈开发程序员的进阶指南,一门学到老的技术
  • 容器服务kubernetes弹性伸缩高级用法
  • 微信端页面使用-webkit-box和绝对定位时,元素上移的问题
  • 我有几个粽子,和一个故事
  • 吴恩达Deep Learning课程练习题参考答案——R语言版
  • 云大使推广中的常见热门问题
  • ​io --- 处理流的核心工具​
  • ​如何在iOS手机上查看应用日志
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • #Js篇:单线程模式同步任务异步任务任务队列事件循环setTimeout() setInterval()
  • #pragma multi_compile #pragma shader_feature
  • (02)Cartographer源码无死角解析-(03) 新数据运行与地图保存、加载地图启动仅定位模式
  • (1)无线电失控保护(二)
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第2节(共同的基类)
  • (MATLAB)第五章-矩阵运算
  • (Pytorch框架)神经网络输出维度调试,做出我们自己的网络来!!(详细教程~)
  • (Redis使用系列) SpirngBoot中关于Redis的值的各种方式的存储与取出 三
  • (二)pulsar安装在独立的docker中,python测试
  • (过滤器)Filter和(监听器)listener
  • (每日持续更新)jdk api之FileFilter基础、应用、实战
  • (南京观海微电子)——COF介绍