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

相关推荐
sin_hielo2 分钟前
leetcode 3512
数据结构·算法·leetcode
Elias不吃糖4 分钟前
LeetCode--130被围绕的区域
数据结构·c++·算法·leetcode·深度优先
念越15 分钟前
二叉树的核心概念与遍历实现(基础详解版)
数据结构
im_AMBER18 分钟前
数据结构 12 图
数据结构·笔记·学习·算法·深度优先
程序员-周李斌18 分钟前
LinkedList 源码深度分析(基于 JDK 8)
java·开发语言·数据结构·list
咫尺的梦想00718 分钟前
链表——删除链表的倒数第 N 个结点
数据结构·链表
梁bk23 分钟前
Redis底层数据结构 -- ziplist, quicklist, skiplist
数据结构·数据库·redis
myw0712051 小时前
湘大头歌程-Ride to Office练习笔记
c语言·数据结构·笔记·算法
H_BB1 小时前
算法详解:滑动窗口机制
数据结构·c++·算法·滑动窗口
淀粉肠kk1 小时前
【C++】封装红黑树实现Mymap和Myset
数据结构·c++