IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【快慢指针_判断链表中是否存在环形_(C语言实现)】 -> 正文阅读

[数据结构与算法]【快慢指针_判断链表中是否存在环形_(C语言实现)】

快慢指针

指的是有两个指针,每次前进的距离不同
快慢指针的起点都一样:
前进快的就是快指针 前进慢的就是慢指针
快指针每次前进2格 慢指针每次前进一格

bool QuikSlow(struct Node* head)
{
	//参数合法性检测
	if (NULL == head)
		return false;
	struct Node* quik = head->pNext;
	struct Node* slow= head->pNext;

	while (quik != NULL && quik->pNext != NULL)
	{
		slow = slow->pNext;
		quik = quik->pNext->pNext;
		if (slow == quik)
			return true;
	}
	return false;
}

(一)检测单链表是否有环:

    定义两个指针,一个快一个慢,两个指针刚开始时都指向链表的头节点,之后快指针每次前进两步,慢指针每次前进一步,如果他们相遇了(fast= low),说明快指针已经转了一圈回来了,也就说明链表有环。

(二)返回环的入口:

     同样定义两个指针,一个指向头节点,另一个指向相遇点,两个指针同时向后走,他们的第一次相遇点就是环的入口。

分析:

    就类似于在操场的跑道上跑步,两个人,快的人的速度是慢的人的两倍,跑的快的人,在第二圈会再次与跑的慢的人相遇。

简单实例实现:

#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#include<stdbool.h>

struct Node
{
	int a;
	struct Node* pPre;
	struct Node* pNext;
};

void Add(struct Node* head, int iData)
{
	//参数合法性检测
	if (NULL == head)
		return;
	//申请节点
	struct Node* pTemp = (struct Node*)malloc(sizeof(struct Node));
	//节点赋值
	if (pTemp == NULL)
		return;
	pTemp->a = iData;
	pTemp->pNext = NULL;
	pTemp->pPre = NULL;
	//链接
	//先连 将新节点连在指定位置
	pTemp->pPre = head->pPre;
	pTemp->pNext = head;
	//后断
	head->pPre->pNext = pTemp;
	head->pPre = pTemp;
}
void Free(struct Node* head)
{
	//参数合法性检测
	if (NULL == head)
		return;
	//申请节点
	struct Node* pTemp = head;
	while (pTemp != head)
	{
		pTemp = pTemp->pNext;
		free(pTemp->pPre);
	}
	head->pPre = head;
	head->pNext = head;
}

bool QuikSlow(struct Node* head)
{
	//参数合法性检测
	if (NULL == head)
		return false;
	struct Node* quik = head->pNext;
	struct Node* slow= head->pNext;

	while (quik != NULL && quik->pNext != NULL)
	{
		slow = slow->pNext;
		quik = quik->pNext->pNext;
		if (slow == quik)
			return true;
	}
	return false;
}
int main()
{
	struct Node head;
	head.a = 0;
	head.pPre = &head;
	head.pNext = &head;
	Add(&head, 1);
	Add(&head, 2);
	Add(&head, 3);
	Add(&head, 4);
	Add(&head, 5);
	Add(&head, 6);

	//变成不循环的
	struct Node* pEnd = head.pPre;
	pEnd->pNext = NULL;
	head.pPre = NULL;

	//变成环
	pEnd->pNext = head.pNext->pNext->pNext;

	bool res = QuikSlow(&head);

	Free(&head);
	return 0;
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-01 17:57:48  更:2021-12-01 18:00:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 14:40:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码