深度广度搜索
发布时间:2020-12-15 00:33:49 所属栏目:C语言 来源:网络整理
导读:table class="text" tr class="li1" td class="ln"pre class="de1"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
<table class="text"> |
<tr class="li1">
<td class="ln"><pre class="de1">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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
0) {
? ? ? ? ? ? ? ? return j;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? return -1;
? ? }
?
? ? //根据前一个邻接结点的下标来取得下一个邻接结点
? ? public int getNextNeighbor(int v1,int v2) {
? ? ? ? for (int j=v2+1;j0) {
? ? ? ? ? ? ? ? return j;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? return -1;
? ? }
? ?
? ? //私有函数,深度优先遍历
? ? private void depthFirstSearch(boolean[] isVisited,int ?i) {
? ? ? ? //首先访问该结点,在控制台打印出来
? ? ? ? System.out.print(getValueByIndex(i)+" ?");
? ? ? ? //置该结点为已访问
? ? ? ? isVisited[i]=true;
? ? ? ?
? ? ? ? int w=getFirstNeighbor(i);//
? ? ? ? while (w!=-1) {
? ? ? ? ? ? if (!isVisited[w]) {
? ? ? ? ? ? ? ? depthFirstSearch(isVisited,w);
? ? ? ? ? ? }
? ? ? ? ? ? w=getNextNeighbor(i,w);
? ? ? ? }
? ? }
? ?
? ? //对外公开函数,深度优先遍历,与其同名私有函数属于方法重载
? ? public void depthFirstSearch() {
? ? ? ? for(int i=0;i
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!