亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? graph.cpp

?? 數(shù)據(jù)結(jié)構(gòu)算法集C++版.好東西大家一起分享。
?? CPP
字號:
//graph.cpp
#include<iostream>
#include "graph.h"//引入頭文件
 
/*
 *前置條件:圖不存在
 *輸    入:無 
 *功    能:圖的初始化
 *輸    出:無
 *后置條件:得到一個有向圖
 */
template <class T>
ALGraph<T>::ALGraph(T a[ ], int n, int e)
{
    arcNum = e;                             //邊數(shù)
	vertexNum=n;                            //頂點(diǎn)數(shù)
    int i,j;
	for (i=0; i<vertexNum; i++)
	{  
       VertexNode<T> tempvertex;
	   tempvertex.vertex = a[i];
	   tempvertex.firstedge = NULL;
	   adjlist[i] = tempvertex;
	}	
	for (int k=0; k<arcNum; k++)           //依次輸入每一條邊,并在相應(yīng)邊表中插入結(jié)點(diǎn)
    { 
		cout<<"請輸入邊所依附的兩個頂點(diǎn)的序號";
		cin>>i>>j;                         //輸入邊所依附的兩個頂點(diǎn)的序號
        ArcNode *s=new ArcNode; s->adjvex=j;  //生成一個邊表結(jié)點(diǎn)s
	    s->next=adjlist[i].firstedge;      //將結(jié)點(diǎn)s插入到結(jié)點(diǎn)i的邊表的表頭  
        adjlist[i].firstedge=s;
	}
	InsertArc(0,1);                   //插入邊
	InsertArc(0,2);
	InsertArc(0,3);
	InsertArc(1,3);
	InsertArc(1,4);
	InsertArc(2,0);
	InsertArc(2,4);
	InsertArc(3,1);
	InsertArc(3,4);
	InsertArc(4,2);
	InsertArc(4,3);
}
/*   前置條件:圖已存在
 *   輸    入:無 
 *   功    能:銷毀圖
 *   輸    出:無
 *   后置條件:釋放圖所占用的存儲空間
 */
template <class T>
ALGraph<T>::~ALGraph( )
{
  for (int i=0; i<vertexNum; i++)
  {
    ArcNode * p=adjlist[i].firstedge;
	while (p!=NULL)                                              //循環(huán)刪除
	{
	  adjlist[i].firstedge=p->next;
	  delete p;                                                 //釋放結(jié)點(diǎn)空間
      p=adjlist[i].firstedge;
	}
  }
}
/*   
 *前置條件:圖已存在
 *輸    入:頂點(diǎn)i
 *功    能:輸出圖中頂點(diǎn)i的數(shù)據(jù)信息
 *輸    出:圖中頂點(diǎn)i的數(shù)據(jù)信息
 *后置條件:圖保持不變
 */
template <class T>
T ALGraph<T>::GetVex(int i)
{
	if ( i>vertexNum || i<0 ) throw "輸入頂點(diǎn)的位置不正確"; //頂點(diǎn)i不存在則拋出異常
	return adjlist[i].vertex;                               //返回第i個頂點(diǎn)的數(shù)據(jù)域  
}

/*
 *前置條件:圖已存在
 *輸    入:頂點(diǎn)i
 *功    能:將圖中頂點(diǎn)i的數(shù)據(jù)域置為value
 *輸    出:無
 *后置條件:圖保持不變
 */
template <class T>
void ALGraph<T>::PutVex(int i, T value)
{
	if ( i>vertexNum || i<0 ) throw "輸入頂點(diǎn)的位置不正確"; //頂點(diǎn)i不存在則拋出異常
	adjlist[i].vertex = value;                              //第i個頂點(diǎn)的數(shù)據(jù)域置為value
}
/*
 *前置條件:圖已存在
 *輸    入:頂點(diǎn)value,位置i
 *功    能:在圖中i位置插入一個頂點(diǎn)name 
 *輸    出:如果插入不成功,拋出異常
 *后置條件:如果插入成功,圖中增加了一個頂點(diǎn)
 */
template <class T>
void ALGraph<T>::InsertVex(int i, T value)
{
	if ( i>vertexNum || i<0 || i>MaxSize ) throw "輸入頂點(diǎn)的位置不正確"; //頂點(diǎn)i不存在則拋出異常
	vertexNum++;                                            //頂點(diǎn)數(shù)加1
	VertexNode<T> tempvertex;
	tempvertex.vertex = value;
	tempvertex.firstedge = NULL;
	adjlist[i] = tempvertex;  	                    //第i個頂點(diǎn)的數(shù)據(jù)域置為value	
}
/*   
 *前置條件:圖已存在
 *輸    入:頂點(diǎn)i 
 *功    能:在圖中刪除頂點(diǎn)i 
 *輸    出:如果刪除不成功,拋出異常
 *后置條件:如果刪除成功,圖中減少了一個頂點(diǎn),相應(yīng)頂點(diǎn)所建立的邊也消去
 */
template <class T>
void ALGraph<T>::DeleteVex(int i)
{
	if ( i<0 || i>MaxSize) throw "位置";       //頂點(diǎn)輸入錯誤則拋出異常
	int k;	
	for ( k=0; k<vertexNum; k++)               //刪掉入度邊
	   if(k!=i)	 DeleteArc(k, i);
	ArcNode *s;                                //生成一個邊表結(jié)點(diǎn)s
	if( adjlist[i].firstedge != NULL)
	{
		ArcNode *s;                         
		s=adjlist[i].firstedge->next;    
		while(s!=NULL)
		{
			ArcNode *p;                      
			p = s;
			adjlist[i].firstedge->next = s->next;
			s=s->next;
			delete p;                        //刪除p結(jié)點(diǎn)
		}
		s=adjlist[i].firstedge;
		adjlist[i].firstedge=NULL;
		delete s;
	}
	for (k=i; k<vertexNum; k++)
	{ 		
	   adjlist[k]=adjlist[k+1];             //存儲頂點(diǎn)信息       
	} 
   vertexNum--;                             //頂點(diǎn)數(shù)減1
   for (k=0; k<vertexNum; k++)
	if( adjlist[k].firstedge != NULL )
	{
		s=adjlist[k].firstedge;                //將結(jié)點(diǎn)s插入到結(jié)點(diǎn)i的邊表的表頭
		while(s!=NULL)
		{
			if(s->adjvex > i)                  //搜索i結(jié)點(diǎn)
				s->adjvex--;
			s = s->next;		
		}			
	}
}
/*   
 *前置條件:圖已存在
 *輸    入:頂點(diǎn)i、j
 *功    能:在圖中插入頂點(diǎn)i、j及其所依附的邊 
 *輸    出:如果插入不成功,拋出異常
 *后置條件:如果插入成功,圖中增加了一條邊
 */
template <class T>
void ALGraph<T>::InsertArc(int i, int j)
{
	if ( i>MaxSize || j>MaxSize) throw "位置";//頂點(diǎn)輸入錯誤則拋出異常
	ArcNode *s=new ArcNode; s->adjvex=j;      //生成一個邊表結(jié)點(diǎn)s
	s->next=adjlist[i].firstedge;             //將結(jié)點(diǎn)s插入到結(jié)點(diǎn)i的邊表的表頭  
    adjlist[i].firstedge=s;	
} 
/* 
 *前置條件:圖已存在
 *輸    入:頂點(diǎn)i、j 
 *功    能:在圖中刪除頂點(diǎn)i、j 依附的邊 
 *輸    出:如果刪除不成功,拋出異常
 *后置條件:如果刪除成功,圖中減少了一條邊
*/
template <class T>
void ALGraph<T>::DeleteArc(int i, int j)
{
	if ( i>MaxSize||  j>MaxSize) throw "位置";  //頂點(diǎn)輸入錯誤則拋出異常
	ArcNode *s;                                 
	ArcNode *tempnode;
	s = adjlist[i].firstedge;
	tempnode = adjlist[i].firstedge;
	while(s!=NULL && s->adjvex!=j)
	{
		tempnode = s;
		s = s->next;
	}
	if(s!=NULL)
	{
		tempnode->next = s->next;
		delete s;
	}	
}
/*   
 *前置條件:圖已存在
 *輸    入:遍歷的起始頂點(diǎn)v
 *功    能:從頂點(diǎn)v出發(fā)深度優(yōu)先遍歷圖
 *輸    出:圖中頂點(diǎn)的一個線性排列
 *后置條件:圖保持不變
 */
template <class T>
void ALGraph<T>::DFSTraverse(int v)
{
	if ( v>vertexNum) throw "位置";                          //頂點(diǎn)輸入錯誤則拋出異常
	ArcNode * p;                                             
	int j;
	cout<<adjlist[v].vertex<<" ";  
	visited[v]=1;
    p=adjlist[v].firstedge;    
   while (p)                                                //依次搜索頂點(diǎn)v的鄰接點(diǎn)j
   {
      j=p->adjvex;
      if (visited[j]==0) DFSTraverse(j);
	  p=p->next;           
   }
}
/*
 *前置條件:圖已存在
 *輸    入:遍歷的起始頂點(diǎn)v
 *功    能:從頂點(diǎn)v出發(fā)廣度優(yōu)先遍歷圖
 *輸    出:圖中頂點(diǎn)的一個線性排列
 *后置條件:圖保持不變
 */
template <class T>
void ALGraph<T>::BFSTraverse(int v)
{
  if ( v>vertexNum) throw "位置";                           //頂點(diǎn)輸入錯誤則拋出異常
  int front,rear,j;
  ArcNode * p;                                              //生成一個邊表結(jié)點(diǎn)p
  int Q[MaxSize];
  front=rear=-1;                                            //初始化隊(duì)列, 假設(shè)隊(duì)列采用順序存儲且不會發(fā)生溢出
  cout<<adjlist[v].vertex<<" ";  visited[v]=1; Q[++rear]=v; //被訪問頂點(diǎn)入隊(duì)
  while (front!=rear)
  {
     v=Q[++front];
     p=adjlist[v].firstedge;                                //邊表中的工作指針p初始化
     while (p) 
	 {
       j= p->adjvex;
       if (visited[j]==0) {
          cout<<adjlist[j].vertex<<" "; visited[j]=1;Q[++rear]=j;
     }
     p=p->next;
	}
  }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合婷婷久久| 欧洲日韩一区二区三区| 无吗不卡中文字幕| 国产精品久久一级| 久久午夜免费电影| 欧美一级在线免费| 制服丝袜中文字幕一区| 一本久道久久综合中文字幕| 国产精品69久久久久水密桃| 日本不卡一二三| 日韩电影在线观看电影| 一区二区三区中文在线| 亚洲欧美成人一区二区三区| 久久久久久久性| 久久久www免费人成精品| 精品国产乱码久久久久久1区2区| 在线影视一区二区三区| 色综合久久综合| 欧美最新大片在线看 | 色爱区综合激月婷婷| 成人黄页毛片网站| 91在线视频免费观看| 亚洲va国产天堂va久久en| 亚洲精品高清在线| 一个色综合av| 亚洲bt欧美bt精品777| 日韩一区精品字幕| 麻豆精品一区二区| 国产一区二区免费看| 国产在线播放一区二区三区| 国产sm精品调教视频网站| 丁香激情综合国产| 精品视频色一区| 欧美成人国产一区二区| 国产精品免费看片| 亚洲成av人片www| 韩国v欧美v日本v亚洲v| 91亚洲精华国产精华精华液| 欧美午夜影院一区| 久久综合久久综合亚洲| 亚洲色图在线视频| 看电视剧不卡顿的网站| 91亚洲精华国产精华精华液| 欧美高清精品3d| 日本一区二区三区在线不卡| 亚洲大片免费看| 国产精品一卡二| 日韩欧美一二三四区| 亚洲欧洲日产国产综合网| 麻豆久久久久久| 在线观看成人小视频| 久久人人超碰精品| 日本午夜一区二区| 欧美性感一区二区三区| 国产精品夫妻自拍| 国产精品影音先锋| 欧美一区三区二区| 亚洲成人www| 91成人看片片| 亚洲男人的天堂在线观看| 国产在线乱码一区二区三区| 91精品国产综合久久香蕉麻豆 | 国产成人啪午夜精品网站男同| 欧美三级中文字幕在线观看| 亚洲精品免费播放| 99久久99久久精品免费观看| 中文字幕第一区综合| 国产成人精品一区二| 国产午夜亚洲精品羞羞网站| 激情综合网最新| 国产色产综合色产在线视频| 国产乱子伦一区二区三区国色天香| 在线不卡a资源高清| 日本成人超碰在线观看| 51精品国自产在线| 日本欧美在线观看| 9191成人精品久久| 九色porny丨国产精品| 久久久99精品久久| 91网站黄www| 亚洲在线中文字幕| 91精品久久久久久久久99蜜臂| 日韩在线播放一区二区| 日韩视频不卡中文| 成人av第一页| 一个色在线综合| 精品国产1区二区| 色噜噜久久综合| 久久99蜜桃精品| 亚洲美女电影在线| 欧美大胆一级视频| 97精品国产露脸对白| 久久精品国产第一区二区三区| 久久精品人人做| 制服丝袜亚洲精品中文字幕| 国产成人精品一区二区三区四区 | 亚洲欧美在线观看| 欧美一区日韩一区| 91精品91久久久中77777| 蜜桃免费网站一区二区三区| 中文欧美字幕免费| 2021久久国产精品不只是精品| 99久久婷婷国产| 国产98色在线|日韩| 日本 国产 欧美色综合| 日韩美女视频一区二区| 国产亚洲欧美日韩俺去了| 欧美久久久久久蜜桃| 欧洲一区在线电影| av中文字幕不卡| 顶级嫩模精品视频在线看| 国产一区亚洲一区| 狂野欧美性猛交blacked| 日韩成人免费电影| 免费在线看一区| 五月综合激情日本mⅴ| 一区二区三区在线高清| 亚洲天堂网中文字| 中文字幕中文字幕在线一区| 久久综合视频网| 国产欧美一区二区精品性| 国产日韩av一区| 国产精品久久久久久久久久久免费看| 精品国产凹凸成av人网站| 精品精品欲导航| 26uuu色噜噜精品一区二区| 久久亚洲春色中文字幕久久久| 欧美tk—视频vk| 欧美国产日韩a欧美在线观看| 久久精品视频网| 亚洲精品一二三| 天天综合网 天天综合色| 日韩vs国产vs欧美| 国产一区在线不卡| 色综合天天综合狠狠| 欧美三级电影网| 久久久不卡网国产精品一区| 中文字幕一区二区三区色视频| 亚洲精品网站在线观看| 日本91福利区| 不卡区在线中文字幕| 欧美日韩国产在线观看| 欧美成人国产一区二区| 中文字幕综合网| 美女视频黄 久久| 欧洲一区二区三区在线| 精品国产网站在线观看| 综合在线观看色| 久久国产精品区| 欧美视频中文一区二区三区在线观看| 精品久久国产字幕高潮| 亚洲欧美色综合| 国产乱人伦精品一区二区在线观看| fc2成人免费人成在线观看播放| 欧美日韩不卡视频| 亚洲欧洲日韩av| 国产精品1024久久| 欧美一区二区三区公司| 一区二区三区在线播| 盗摄精品av一区二区三区| 日韩一区二区免费在线观看| 亚洲品质自拍视频| 国产精品小仙女| 欧美精品一区二区高清在线观看| 亚洲国产一区二区视频| 99视频精品在线| 中文字幕一区三区| 国产乱国产乱300精品| 欧美精品一区二区三区蜜桃| 美女一区二区久久| 欧美电影免费观看高清完整版在线| 亚洲国产精品一区二区www | 一区二区不卡在线播放 | 国产精品亲子伦对白| 国产成人精品www牛牛影视| 久久久亚洲国产美女国产盗摄 | 久久久国产精品午夜一区ai换脸| 久久精品国产精品亚洲综合| 日韩欧美成人激情| 国产在线视频一区二区| 久久婷婷色综合| 成人免费看视频| 一区二区三区在线视频观看58| 欧洲人成人精品| 久久精品久久精品| 国产精品乱码一区二区三区软件 | 国产精品888| 亚洲愉拍自拍另类高清精品| 欧美三区在线视频| 九色porny丨国产精品| 中文字幕在线视频一区| 一本色道亚洲精品aⅴ| 免费成人你懂的| 亚洲人成网站精品片在线观看 | 亚洲日本va午夜在线影院| 欧美日韩精品一区视频| 国产自产2019最新不卡| 亚洲欧洲日韩女同| 精品国产sm最大网站| 99久久亚洲一区二区三区青草|