24.8.2数据结构|双链表

双链表

1、**定义结构:**2个指针域、数据域

2、**初始化:**创建一个含有N个结点的带头结点双链表head

(双链表头结点的前驱与和尾节点的后继与置为空)

3、**求表长:**返回双链表head的长度

4、取元素:取出双链表head中第I个结点的值, I的取值范围是小于等于N大于等于1.

5、定位:返回双链表head中第一个值为X的节点的位置

6、删除:删除双链表head中的第i个节点

7、插入:在双链表head中第I个结点之前插入一个值为X的结点

8、输出:从两个方向输出双链表head中各节点的值

复制代码
void fun(LinkList*head){
	LinkList*p,*q;
	int i;
	for(q=head;q->next!=NULL;q=q->next);
	p=head;
	while(p!=q){
		while(p->date<0)p=p->next;
		while(q->date>0)q=q->pre;
		if(p!=q){
			//交换
			int t;
			t=p->date;
			p->date=q->date;
			q->date=t;
		 
		}
	}
}
//把所有不小于零的节点放在所有值小于零的节点之前  

单向循环链表

单向循环链表与单链表的结点类型完全相同差别 仅在于算法中的循环条件 不是判断P或P指向next是否为空而是判断它们是否等于头指针

1、定义:结构体单向循环链表的类型与单向链表的类型一样

2、初始化:创建一个含有N个结点的带头结点单向循环链表head。

3、求表长:返回单向循环链表head的表长

4、取元素:取出单向循环链表head的第I个节点的元素值

5、定位:在单向循环head中查找第一个值为X的结点

6、删除:删除带头结点单向循环链表head中的第i个结点

7、插入:操作在带头结点单向循环链表head中的第二个结点之前插入一个值为X的结点

8、输出:带头结点增效循环列表hard中的各点的值

头结点里边没有数据作为一个判断标准存在把。

例题

由N个已经按1,2,3,...,n编号的人围成一圈,从编号为1的人开始按1,2,3顺序循环报数,凡报到3者退出,最后只留一个人,问其编号是多少?(用带头结点单向循环链表实现)

自解:

复制代码
int fun(LinkList *fhead,int n){
//用单向循环连表
 LinkList*p;
 p=head->next;
 int i=1;
 while(p!=NULL){
 	p=p->next;
 	i++;
 	if(i==2&&p->next!=NULL){
 		p->next=p->next->next;
 		i=0;
	 }
 }printf("%d\n",p->date);
 return 1;
}

应该对吧???

注意释放删除后的内存

课本是:(int n)只有n

相关推荐
汉克老师20 分钟前
GESP6级C++考试语法知识(十七、数据结构(三、认识队列 Queue))
数据结构·c++·队列·gesp6级·gesp六级·数组模拟队列
JavaWeb学起来1 小时前
Python学习教程(六)数据结构List(列表)
数据结构·python·python基础·python教程
啊董dong4 小时前
noi-2026年5月12号小测验
数据结构·c++·算法
南境十里·墨染春水4 小时前
数据结构 —— 链表
数据结构·链表
图码5 小时前
二分查找进阶:如何在有序数组中快速找到Upper Bound?
数据结构·算法·面试·分类·柔性数组
Cthy_hy5 小时前
树状数组(BIT)进阶:差分优化实现区间修改、区间查询
数据结构·python·算法
代码中介商7 小时前
红黑树完全指南:从五条性质到完整插入删除实现
数据结构·算法
Sarvartha9 小时前
单链表的顺序建立与结点的删除(期末题复现)
数据结构
Dlrb121110 小时前
数据结构-链表
数据结构·链表·逻辑结构·单向链表·物理结构·valgrind工具
小的~~10 小时前
算法题:只出现一次的数字
数据结构·算法