1 问题
判断链表是否包含环
2 思路
2个指针,一个指针走一步,一个指针走2步,如果相遇则有,反之无。
3 代码实现
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
#include <stdio.h>
#include <stdlib.h>
#define true 1
#define false 0;
typedef struct node
{
int value;
struct node *next;
}Node;
/*
*判断链表是否有环
*/
int isCircleList(Node *head)
{
if (head == NULL)
{
return false ;
}
Node *first = NULL;
Node *second = NULL;
first = head;
second = head;
while (second != NULL && (second->next) != NULL && (second->next->next != NULL))
{
first = first->next;
second = second->next->next;
if (first == second)
{
return true ;
}
}
return false ;
}
int main()
{
Node *head = NULL;
Node *node1 = NULL;
Node *node2 = NULL;
Node *node3 = NULL;
Node *node4 = NULL;
Node *node5 = NULL;
Node *node6 = NULL;
Node *node7 = NULL;
head = (Node *) malloc ( sizeof (Node));
node1 = (Node *) malloc ( sizeof (Node));
node2 = (Node *) malloc ( sizeof (Node));
node3 = (Node *) malloc ( sizeof (Node));
node4 = (Node *) malloc ( sizeof (Node));
node5 = (Node *) malloc ( sizeof (Node));
node6 = (Node *) malloc ( sizeof (Node));
node7 = (Node *) malloc ( sizeof (Node));
if (head == NULL || node1 == NULL || node2 == NULL || node3 == NULL
|| node4 == NULL || node5 == NULL || node6 == NULL || node7 == NULL)
{
printf ( "malloc fail\n" );
return false ;
}
// node7<-node6 <-node5
// | |
//head->node1->node2->node3->node4
head->value = 0;
head->next = node1;
node1->value = 1;
node1->next = node2;
node2->value = 2;
node2->next = node3;
node3->value = 3;
node3->next = node4;
node4->value = 4;
node4->next = node5;
node5->value = 5;
node5->next = node6;
node6->value = 6;
node6->next = node7;
node7->value = 7;
node7->next = node2;
int result = isCircleList(head);
if (result)
{
printf ( "list have circle\n" );
}
else
{
printf ( "list do not have circle\n" );
}
return true ;
}
|
4 运行结果
1
|
list have circle
|
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://blog.csdn.net/u011068702/article/details/87748768