vs2022链表的创建和打印(c语言版)

链表

链表和顺序表

链表相较于顺序表在创建和打印上还是比较麻烦的,对于新手来说是一大难点。那为什么还要使用链表呢?主要是顺序表在插入数据和删除数据上显得很麻烦,需要去移动大量数据才能实现一个数据的插入或者删除。而链表采用动态内存的方法,简化了插入与删除这一步骤。

什么是链表?

在c语言中,链表主要是通过构建结构体来实现的,结构体中有两个属性,一是我们要存储的数据,二是下一个结点的地址指针。

相当于在空间存储结构上,链表的结点与结点之间是没有关系的,它通过后面这个指针来将数据连接起来。这样的话,插入与删除就只需要处理这一个结点以及前后结点的连接的问题。

结点

既然,链表是由一个又一个结点构成,那么先来搭建一个结构体出来。

c 复制代码
struct Node
{
	int data;
	struct Node *next;
};

一个数据,一个指针。

创建链表(结点与结点进行连接)

c 复制代码
struct Node* createList()
{
	struct Node *head = NULL;
	struct Node *p, *q=NULL;
	//创建一个n长度的链表
	int n,a;
	scanf_s("%d", &n);
	for (int i = 0; i < n; i++)
	{
		scanf_s("%d", &a);
		//为p分配一个内存位置
		p = (struct Node*)malloc(sizeof(struct Node));
		p->data = a;
		p->next = NULL;
		//如果头节点是空的,就将p设为头节点
		if (head == NULL) 
		{ 
			head = p; 
		}
		//如果有了头节点,就让上一个暂存的节点连接到这次开辟的节点上
		else 
		{ 
			q->next = p; 
		}
		//q为暂时保存节点
		q = p;
	}
	return head;
}

打印链表

c 复制代码
void readList(struct Node* head)
{
	//遍历整个链表
	struct Node *t;
	t = head;
	while (t != NULL)
	{
		printf("%d\n", t->data);
		t = t->next;
	}
}

主要报错

vs2022这个环境还是比较严苛的,会遇到一些严格的报错。

严重性 代码 说明 项目 文件 行 禁止显示状态 详细信息

错误 C4996 'scanf': This function or variable may be unsafe. Consider using scanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details. 单向链表 D:\Cproject\Data_Structure\线性表\单向链表\单向链表\main.cpp 16

这个报错是指它认为scanf可能是不够安全的,建议我们使用scanf_s代替

严重性 代码 说明 项目 文件 行 禁止显示状态 详细信息

错误 C4703 使用了可能未初始化的本地指针变量"q" 单向链表 D:\Cproject\Data_Structure\线性表\单向链表\单向链表\main.cpp 32

这个报错是指q未被初始化,但是问题是我的q是作为一个暂存指针存在的,每次只要接收复制q就可以了,按理说,初始化不初始化影响不大,但是vs2022就是不给我运行。无奈之下,只能在初始化q=NULL。

相关推荐
想不明白的过度思考者2 分钟前
数据结构(排序篇)——七大排序算法奇幻之旅:从扑克牌到百亿数据的魔法整理术
数据结构·算法·排序算法
一支闲人14 分钟前
C语言相关简单数据结构:双向链表
c语言·数据结构·链表·基础知识·适用于新手小白
姜不吃葱34 分钟前
【力扣热题100】双指针—— 接雨水
数据结构·算法·leetcode·力扣热题100
拂晓银砾1 小时前
Java数据结构-队列
java·数据结构
John.Lewis1 小时前
数据结构初阶(19)外排序·文件归并排序的实现
c语言·数据结构·排序算法
John.Lewis1 小时前
数据结构初阶(16)排序算法——归并排序
c语言·数据结构·排序算法
tanyongxi661 小时前
C++ 特殊类设计与单例模式解析
java·开发语言·数据结构·c++·算法·单例模式
wearegogog1232 小时前
C语言中的输入输出函数:构建程序交互的基石
c语言·开发语言·交互
闪电麦坤953 小时前
数据结构:在二叉搜索树中插入元素(Insert in a BST)
数据结构·二叉树··二叉搜索树
闪电麦坤953 小时前
数据结构:用链式队列实现层序遍历 (Level-order Traversal)
数据结构··遍历