顺序表和链表实例以及代码实现 数据结构严第二章

本文介绍了数据结构中顺序表和链表的基本操作,包括顺序表的插入、删除以及链表的插入、删除,并讨论了它们的时间复杂度。此外,提到了链表在广义表和多重链表中的应用,以及它们在空间复杂度上的优势。顺序表由于插入和删除需要大量移动元素,时间复杂度较高,而链表则相对高效但牺牲了随机访问能力。链表的灵活结构使其在特定场景下更具优势。
摘要由CSDN通过智能技术生成

数据结构严第二章顺序表和链表

顺序表(直接上代码)

顺序表这里我认为难点在与插入和删除时对其它元素的全部左移或者右移,正因为这点导致他的时间复杂度很高(删除或者插入一个元素在最坏的情况下需要改动其它所有元素的位置
但是仔细观察也并不能算是难点。

#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#define maxn 10000
typedef int position;
typedef struct LNode
{
	int data[maxn];
	position Last;
}  *List   ;
List MakeEmpty()      //建立一个新表
{
	List L;
	L = (List)malloc(sizeof(struct LNode));
		return L;
}
//查找
int Find(List L, int X)
{
	int i = 0;
	while (i <= L->Last && L->data[i] != X)
		i++;
	if (i > L->Last) return 0;
	else return i;
}
//插入
bool Insert(List L, int X, int p)
//在指定的位置p前,插入元素x;(p指的是数组下标)
{
	int i;
	if (L->Last == maxn - 1)
		return 0;
	if (p<0 || p>L->Last)
	{
		printf("位置不合法");
			return 0;
	}
	for (i = L->Last; i >= p; i--)
	{
		L->data[i + 1] = L->data[i];
	}
	L->data[p] = X;
	L->Last++;					//使Last仍然指向最后一个元素
	return 1;
}
//删除
bool Delete(List L, int p)
//删除指定位置p的元素
{
	int i;
	if (p<0 && p>L->Last)
		return 0;
	for (i = p ; i <= L->Last--; i++)
	{
		L->data[i] = L->data[i + 1];
	}
	L->Last--;
	return 1;
}

链表

链表这里的删除和插入就简单了许多,时间复杂度就降低了,但是随之带来的缺陷是我们无法随机查找元素了,因为是链表所以我们要一个节点一个节点的去查。


#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
typedef struct  list
{
	int data;
	struct list *next;
}*linklist, list, * position;
void print(linklist L);				//输出链表
linklist creat(int n);				//创建链表的声明
position findnode(linklist L, int x);	//返回第x个元素的位置
bool insert(linklist L, int x, int y);	//在第x个元素钱插入数据为y的节点
bool delet(linklist L, int x);				//删除第x个节点
int main()
{
	linklist head = NULL;
	linklist L;
	int n = 0;
	printf("请输入你要创建的链表的个数");
	scanf_s("%d", &n);
	L = creat(n);
	print(L);
}
linklist creat(int n)
{
	linklist L, p, q;
	int i = 0;
	L = (linklist)malloc(sizeof(list));
	if (!L) return 0;
	L->next = NULL;
	q = L ;
	while (i < n)
	{
		p = (linklist)malloc(sizeof(list));
		scanf_s("%d", &(p->data));
		q->next = p;
		p->next = NULL;
		q = p;
		i++;
	}
	return L;
}
void print(linklist L)
{
	linklist p=L->next ;
	while (p)
	{
		printf("%d\n", (p->data));
		p = p->next;
	}
	return ;
}


这里我加一点其它的东西就是关于链表的应用什么的。

广义表

直接上图
在这里插入图片描述

多重链表

感觉还蛮有用的可以降低空间复杂度什么的,但是我还不知道咋实现。
在这里插入图片描述

如有帮助请点赞鼓励一下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值