数据结构day4链表作业

一、链表的剩下操作

  1. listLinkPtr.h
cpp 复制代码
//任意位置删除
int index_del(linkListPtr H, int index);

//按位置修改
int index_change(linkListPtr H, int index, DataType e);

//按值查找返回地址
linkListPtr node_addr(linkListPtr H, DataType e);

//反转
//int node_rever(linkListPtr H);

//销毁
void my_free(linkListPtr H);
  1. listLinkPtr.c
cpp 复制代码
//------------------------------------------------------------------
//任意位置删除
int index_del(linkListPtr H, int index)
{
	//判断所接受的链表是否合法
	//判空
	//判断删除位置是否合法
	if(NULL== H || empty(H) || index<1 || index>H->len)
	{
		printf("删除失败!\n");
		return 0;
	}
	//定义一个指针指向删除位置的前一个节点
	linkListPtr q = H;
	for(int i=0; i<index-1; i++)
	{
		q=q->next;
	}
	//删除	
	linkListPtr p = q->next;
	q->next=q->next->next;
	free(p);
	p=NULL;
	//删除成功,链表长度自减
	H->len--;
	return 1;
}

//按位置修改
int index_change(linkListPtr H, int index, DataType e)
{
	//判断所接受的链表是否合法
	//判空
	//判断删除位置是否合法
	if(NULL== H || empty(H) || index<1 || index>H->len)
	{
		printf("修改失败!\n");
		return 0;
	}
	//定义一个指针指向要修改位置的节点
	linkListPtr p = H;
	for(int i=0; i<index; i++)
	{
		p=p->next;
	}
	//修改数据
	p->data=e;
	return 1;
}


//按值查找返回地址
linkListPtr node_addr(linkListPtr H, DataType e)
{
	//判断所接受的链表是否合法
	//判空
	if(NULL== H || empty(H))
	{
		printf("查询失败!\n");
		return 0;
	}
	//定义一个指针指向要查询的值的节点位置
	linkListPtr p = H;

	for(int i=0; i<H->len; i++)
	{
		p = p->next;
		if(p->data == e)
		{
			return p->next;
		}
	}
	printf("无此数据!\n");
	return NULL;

/*
	//for循环以外的另一种方法
	while(p->next != NULL)
	{
		p = p->next;
		if(p->data == e)
		{
			return p->next;
		}
	}
	printf("无此数据!\n");
	return NULL;
*/

}

/*
//反转
int node_rever(linkListPtr H)
{
	//判断所接受的链表是否合法
	//判空
	if(NULL== H || empty(H))
	{
		printf("查询失败!\n");
		return 0;
	}
	//
}
*/


//销毁
void my_free(linkListPtr H)
{
	//判断所接受的链表是否合法
	if(NULL == H)
	{
		printf("销毁失败!\n");
		return;
	}
	linkListPtr p = H;
	for(int i=0; i<H->len; i++)
	{	
		p = H;
		for(int j=0; j<H->len-i-1; j++)
		{
			p = p->next;
		}
		free(p->next);
		p=NULL;
	}
	free(H);
	H=NULL;
	p=NULL;
	printf("销毁成功!\n");
}
  1. main.c
cpp 复制代码
	printf("-----------------------\n");
	//任意位置删除
	index_del(H, 3);
	show(H);

	//按位置修改
	index_change(H, 3, 99);
	show(H);
	
	//按值查找返回地址
	linkListPtr p = node_addr(H, 99);
	printf("%p\n", p);

	//反转
	//node_rever(H);
	//show(H);
	
	//销毁
	my_free(H);
	H=NULL;
	return 0;
  1. 执行结果

二、链表知识点思维导图

相关推荐
SsummerC10 小时前
【leetcode100】每日温度
数据结构·python·leetcode
jingshaoyou10 小时前
Strongswan linked_list_t链表 注释可独立运行测试
数据结构·链表·网络安全·list
逸狼13 小时前
【Java 优选算法】二分算法(下)
数据结构
云 无 心 以 出 岫16 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
姜威鱼17 小时前
蓝桥杯python编程每日刷题 day 21
数据结构·算法·蓝桥杯
神里流~霜灭18 小时前
蓝桥备赛指南(12)· 省赛(构造or枚举)
c语言·数据结构·c++·算法·枚举·蓝桥·构造
扫地的小何尚18 小时前
NVIDIA工业设施数字孪生中的机器人模拟
android·java·c++·链表·语言模型·机器人·gpu
双叶83618 小时前
(C语言)单链表(1.0)(单链表教程)(数据结构,指针)
c语言·开发语言·数据结构·算法·游戏
学习编程的gas19 小时前
数据结构——队列的实现
数据结构
wuqingshun31415919 小时前
蓝桥杯 切割
数据结构·c++·算法·职场和发展·蓝桥杯