【王道2023考研计算机数据结构复习指导课后代码题】——06.在递增有序的单链表中删除重复元素

【王道2023考研计算机数据结构复习指导课后代码题】——06.在递增有序的单链表中删除重复元素,第1张

文章目录
  • 一【题目类别】
  • 二【题目来源】
  • 三【题目描述】
  • 四【解题思路】
  • 五【时间频度】
  • 六【代码实现】
  • 七【程序测试】

一【题目类别】
  • 单链表
二【题目来源】
  • 本题目选自王道2023考研计算机数据结构复习指导40页中二、综合应用题之12题
三【题目描述】
  • 在一个递增有序的线性表中,有数值相同的元素存在。若存储方式为单链表,设计算法去掉数值相同的元素,使表中不再有重复的元素,例如(7,10,10,21,30,42,42,42,51,70)将变为(7,10,21,30,42,51,70)。
四【解题思路】
  • 这个题目与【王道2023考研计算机数据结构复习指导课后代码题】——02.在有序顺序表中删除重复元素几乎一样,但是由于一个是顺序表,一个是单链表,所以代码上稍有不同,都是利用数据有序的前提,值相同的元素是“连续”存储的,所以直接定义两个指针,将重复元素删除即可。要注意:顺序表与单链表删除数据元素的时间复杂度是不同的。而且顺序表是判断不同值时进行处理,而单链表是判断相同值时进行处理
五【时间频度】
  • 时间复杂度: O ( n ) O(n) O(n),其中 n n n为单链表长度
  • 空间复杂度: O ( 1 ) O(1) O(1)
六【代码实现】
/*王道2023考研计算机数据结构复习指导40页中二、综合应用题之12题*/

/*去除警告*/
#define _CRT_SECURE_NO_WARNINGS

/*引入头文件*/
#include
#include

/*声明定义结点结构体,其中包括数据和指向下一个结点的指针*/
typedef struct LNode
{
	int data;
	struct LNode* next;/*这里就是指向下一个结点的指针,*表示这是一个指针,next是这个指针的名字,struct表示这个指针指向的内容是个结构体*/
}Node, *Link;/*这里需要说明Node为结构体的名字,也就是typedef给结构体struct LNode定义了一个别名,这个别名叫Node,而*Link表示一个结构体指针,声明变量的时候要使用malloc开辟内存空间或者指向某一个已经声明的结构体;还有一个区别在于带*定义结构体指针的时候,取内部数据元素的时候要用->,而不带*的知识一个普通的结构体变量,取元素的时候要用.*/

/*打印单链表*/
void PrintLink_Del_Same(Link link)
{
	Node* p = link->next;
	while (p != NULL)
	{
		if (p->next != NULL)
		{
			printf("%d->", p->data);
		}
		else
		{
			printf("%d", p->data);
		}
		p = p->next;
	}
}

/*此函数的功能为删除有序的带头结点的单链表中的重复元素*/
void Del_Same(Link L)
{
	Link p = L->next;
	Node* temp = (Node*)malloc(sizeof(Node));
	if (p == NULL)
	{
		return;/*如果单链表为空,结束程序*/
	}
	while (p->next != NULL)
	{
		temp = p->next;/*temp指向p的后继结点*/
		if (p->data == temp->data)/*找到重复值的结点*/
		{
			p->next = temp->next;/*跳过重复值结点,重新链接单链表*/
			free(temp);/*释放值相同元素结点*/
		}
		else
		{
			p = p->next;/*不是重复值的结点继续向下寻找*/
		}
	}
}

/*主函数*/
int main()
{
	Link link = (Link)malloc(sizeof(Node));
	link->next = NULL;
	Node* p = link;
	int len;
	printf("请输入单链表的长度:");
	scanf("%d", &len);/*输入单链表长度*/
	printf("请输入单链表的元素:");
	for (int i = 0; i < len; i++)/*扫描数据建立单链表*/
	{
		int x;
		scanf("%d", &x);
		Node* temp = (Node*)malloc(sizeof(Node));
		temp->data = x;
		temp->next = NULL;
		p->next = temp;
		p = temp;
	}
	printf("初始单链表为:");
	PrintLink_Del_Same(link);
	printf("\n");
	Del_Same(link);
	printf("删除重复元素后的单链表为:");
	PrintLink_Del_Same(link);
	printf("\n");
	/*暂停程序*/
	system("pause");
	/*函数结束*/
	return 0;
}
七【程序测试】

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1325156.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-12
下一篇 2022-06-12

发表评论

登录后才能评论

评论列表(0条)

保存