亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java廣度優先遍歷怎么實現

發布時間:2021-12-08 14:06:44 來源:億速云 閱讀:188 作者:iii 欄目:大數據

本篇內容主要講解“Java廣度優先遍歷怎么實現”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java廣度優先遍歷怎么實現”吧!

廣度優先遍歷 breadth first search   BFS 

圖的深度優先遍歷類似與樹的前序遍歷,  廣度優先遍歷類似與樹的 層序 遍歷。

void printNodeByLevel(NODE* root)//Tree層序遍歷
{
	if(root == NULL)
	{
		return;
	}
	vector<NODE*>vec;
	vec.push_back(root);
	int cur=0;
	while(cur<vec.size())
	{
		cout<<vec[cur]->data<<" ";
		if(vec.[cur]->left != NULL)
		{
			vec.push_back(vec.[cur]->left);
		}
		if(vec.[cur]->right != NULL)
		{
			vec.push_back(vec.[cur]->right);
		}
		++cur;
	}
	cout<<endl;
}


類似于一個分層搜索的過程,廣度優先遍歷需要使用一個隊列以保持訪問過的結點的順序,以便按這個順序來訪問這些結點的鄰接結點。

具體算法表述如下:

  1. 訪問初始結點v并標記結點v為已訪問。

  2. 結點v入隊列

  3. 當隊列非空時,繼續執行,否則算法結束。

  4. 出隊列,取得隊頭結點u。

  5. 查找結點u的第一個鄰接結點w。

  6. 若結點u的鄰接結點w不存在,則轉到步驟3;否則循環執行以下三個步驟:

    1). 若結點w尚未被訪問,則訪問結點w并標記為已訪問。
    2). 結點w入隊列
    3). 查找結點u的繼w鄰接結點后的下一個鄰接結點w,轉到步驟6。


如下圖,其廣度優先算法的遍歷順序為:1->2->3->4->5->6->7->8

Java廣度優先遍歷怎么實現


廣度遍歷-鄰接矩陣
bool visited[MAX];
void BFSTraverse(MGraph G)
{
	for(int i=0;i<G.numV; i++)
	{
		visited[i] = false;
	}
	Queue tempQ;  
	InitQueue(& tempQ);//初始化建立一個隊列
	for(int i=0;i<G.numV; i++)
	{
		if(! visited[i])//如果沒訪問過就處理
		{
			visited[i] = true;
			cout<<G.ArrVex[i];
			enQueue(&Q,i)//將此頂點入隊列
			while(! QueueEmpty(Q))//如果當前隊列不為空
			{
				DeQueue(&Q,&i);//將隊中元素出隊列 賦值給i;
				for(int j=0;j<G.numV;j++)
				{
					if(G.arc[i][j]==1 && !visited[j])
					{
						visited[j] = true;
						cout<< G.ArrVex[j];
						EnQueue(&Q,j);
					}
				}
			}
		}
	}
	
}


鄰接表 

鄰接表 BFS 遍歷
bool visited[MAX];  
void BFSTraverse(MGraph G)  
{  
    for(int i=0;i<G.numV; i++)  
    {  
        visited[i] = false;  
    }  
    Queue tempQ;    
    InitQueue(& tempQ);//初始化建立一個隊列  
    for(int i=0;i<G.numV; i++)  
    {  
        if(! visited[i])//如果沒訪問過就處理  
        {  
            visited[i] = true;  
            cout<<G.adjlist[i].data;  
            enQueue(&Q,i)//將此頂點入隊列  
            while(! QueueEmpty(Q))//如果當前隊列不為空  
            {  
                DeQueue(&Q,&i);//將隊中元素出隊列 賦值給i;
                EdgeNode* p =NULL;
                p=G.adjlist[i].firstedge;
                while(p)
                {
                    if(!visited[p->adjvex])  
                    {  
                        visited[p->adjvex] = true;  
                        cout<< adjlist[j].data;  
                        EnQueue(&Q,j);  
                    }
                     p=p->next;
                }  
            }  
        }  
    }  
      
}

到此,相信大家對“Java廣度優先遍歷怎么實現”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平和县| 浑源县| 台北县| 自治县| 峡江县| 大渡口区| 巧家县| 怀仁县| 霍州市| 库尔勒市| 卢龙县| 屯留县| 新田县| 文成县| 娱乐| 西峡县| 河津市| 驻马店市| 新巴尔虎右旗| 广平县| 柘城县| 海丰县| 三江| 浦县| 辛集市| 如东县| 嘉鱼县| 太白县| 习水县| 错那县| 蒙山县| 汉川市| 鹰潭市| 义乌市| 大埔区| 新营市| 通江县| 安福县| 抚顺县| 怀来县| 亚东县|