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

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

?? graph.cpp

?? 我學習時候的數(shù)據(jù)結(jié)構(gòu)程序!都是自己經(jīng)驗的總結(jié)
?? 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;                            //頂點數(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é)點
    { 
		cout<<"請輸入邊所依附的兩個頂點的序號";
		cin>>i>>j;                         //輸入邊所依附的兩個頂點的序號
        ArcNode *s=new ArcNode; s->adjvex=j;  //生成一個邊表結(jié)點s
	    s->next=adjlist[i].firstedge;      //將結(jié)點s插入到結(jié)點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é)點空間
      p=adjlist[i].firstedge;
	}
  }
}
/*   
 *前置條件:圖已存在
 *輸    入:頂點i
 *功    能:輸出圖中頂點i的數(shù)據(jù)信息
 *輸    出:圖中頂點i的數(shù)據(jù)信息
 *后置條件:圖保持不變
 */
template <class T>
T ALGraph<T>::GetVex(int i)
{
	if ( i>vertexNum || i<0 ) throw "輸入頂點的位置不正確"; //頂點i不存在則拋出異常
	return adjlist[i].vertex;                               //返回第i個頂點的數(shù)據(jù)域  
}

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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文一区二区在线观看| 日本伊人精品一区二区三区观看方式| 亚洲视频1区2区| 日韩国产欧美在线视频| 国产夫妻精品视频| 欧美高清视频在线高清观看mv色露露十八 | 久久99这里只有精品| 99视频热这里只有精品免费| 日韩亚洲欧美成人一区| 伊人色综合久久天天人手人婷| 黄色日韩三级电影| 欧美一级黄色大片| 亚洲成av人片在线观看| 91麻豆国产自产在线观看| 欧美精品一区二| 亚洲不卡av一区二区三区| 91一区二区三区在线观看| 国产欧美综合色| 国产精品一品二品| 精品日韩在线一区| 免费在线观看视频一区| 7777精品伊人久久久大香线蕉经典版下载| 国产精品大尺度| 夫妻av一区二区| 欧美国产激情二区三区| 国产成人av影院| 久久综合九色欧美综合狠狠| 蜜桃久久久久久| 69精品人人人人| 天天av天天翘天天综合网| 欧美综合在线视频| 亚洲午夜精品网| 欧美日韩在线观看一区二区 | 久久色成人在线| 秋霞成人午夜伦在线观看| 欧美日韩综合色| 午夜精品影院在线观看| 色综合网色综合| 亚洲激情欧美激情| 欧美日精品一区视频| 婷婷久久综合九色综合伊人色| 欧美日韩1区2区| 亚洲一区二区三区四区中文字幕| 欧美视频一区在线| 日韩高清一区二区| 日韩久久久久久| 国产精品一区二区三区乱码| 久久影音资源网| 99精品欧美一区二区三区小说 | 91福利视频在线| 亚洲综合色噜噜狠狠| 欧美喷潮久久久xxxxx| 亚州成人在线电影| 欧美精品一区二区三区视频| 久久99精品久久久久久| 欧美经典一区二区| 在线观看视频91| 日本vs亚洲vs韩国一区三区二区| 精品国产欧美一区二区| 成熟亚洲日本毛茸茸凸凹| 夜夜精品视频一区二区 | 在线看不卡av| 毛片不卡一区二区| 中文一区二区完整视频在线观看 | 亚洲成人黄色影院| 日韩欧美一二三四区| 成人一区二区三区在线观看| 一区二区三区.www| 日韩欧美一级二级三级久久久| 国产黄人亚洲片| 五月激情综合色| 精品国精品自拍自在线| 91麻豆国产福利在线观看| 婷婷丁香久久五月婷婷| 国产人成亚洲第一网站在线播放| 91国偷自产一区二区三区观看| 美女性感视频久久| 亚洲精品写真福利| 久久网站热最新地址| 欧美日韩高清在线| 国产v综合v亚洲欧| 日韩有码一区二区三区| 国产午夜久久久久| 91精品麻豆日日躁夜夜躁| 99视频精品全部免费在线| 久久狠狠亚洲综合| 亚洲女人小视频在线观看| 精品国产乱码久久久久久浪潮| 色婷婷综合久久久| 国产一区二区在线视频| 首页亚洲欧美制服丝腿| 亚洲欧洲国产专区| 久久久久久一二三区| 制服丝袜av成人在线看| 菠萝蜜视频在线观看一区| 九九国产精品视频| 日一区二区三区| 亚洲图片欧美综合| 亚洲欧美日韩久久| 国产精品麻豆一区二区| 久久久综合视频| 日韩午夜电影av| 欧美日韩精品电影| 在线亚洲免费视频| 99r国产精品| 99久久婷婷国产综合精品 | 亚洲国产岛国毛片在线| 91精品国产综合久久久久| 99久久国产综合色|国产精品| 国产盗摄一区二区三区| 久久99国内精品| 免费av成人在线| 日韩精品亚洲专区| 天堂在线一区二区| 偷拍日韩校园综合在线| 亚洲第一狼人社区| 亚洲一二三区视频在线观看| 亚洲国产中文字幕在线视频综合| 亚洲精品一二三| 亚洲一区二区三区三| 国产麻豆日韩欧美久久| 免费在线欧美视频| 麻豆成人av在线| 久久疯狂做爰流白浆xx| 国内久久婷婷综合| 国产一区二区在线电影| 国产剧情一区二区| 成人av网站在线| 99久久精品国产导航| 一本久久综合亚洲鲁鲁五月天 | 亚洲精品国产无套在线观| 国产精品家庭影院| 亚洲色图欧美偷拍| 亚洲高清免费观看高清完整版在线观看| 亚洲激情校园春色| 蜜臀av性久久久久蜜臀aⅴ流畅| 久久精品久久综合| 丁香激情综合国产| 日本韩国欧美三级| 91麻豆精品久久久久蜜臀| 日韩精品专区在线影院观看 | 一个色综合av| 日本视频一区二区三区| 激情丁香综合五月| 91污在线观看| 91精品午夜视频| 欧美激情一区二区三区蜜桃视频| 国产精品成人在线观看| 亚洲成va人在线观看| 九色综合狠狠综合久久| 91年精品国产| 日韩精品一区二区三区三区免费| 国产精品视频一二三区| 一区二区免费在线播放| 日本网站在线观看一区二区三区 | 成人高清av在线| 欧美三级午夜理伦三级中视频| 5858s免费视频成人| 精品剧情v国产在线观看在线| 久久久精品一品道一区| 亚洲成人中文在线| 狠狠狠色丁香婷婷综合激情| 国产69精品久久久久777| 97久久超碰精品国产| 精品久久久久一区| 久久久久成人黄色影片| 亚洲人成网站影音先锋播放| 亚洲精品一二三| 毛片av一区二区三区| 99免费精品视频| 91精品国产色综合久久不卡电影| 1024精品合集| 精品一区二区免费视频| 91丨porny丨首页| 欧美怡红院视频| 国产精品初高中害羞小美女文| 丝袜美腿亚洲一区| av中文一区二区三区| 日韩一区二区三区高清免费看看| 国产清纯白嫩初高生在线观看91 | 久久综合狠狠综合久久综合88 | 国产精品色噜噜| 日本中文一区二区三区| 激情偷乱视频一区二区三区| 欧美日韩免费视频| 精品国产1区二区| 美美哒免费高清在线观看视频一区二区 | 午夜精品成人在线| 色综合久久综合中文综合网| 欧美xxxxxxxx| 亚洲成人免费看| 国产成人av影院| 国产日韩精品久久久| 人人爽香蕉精品| 色天天综合色天天久久| 久久久国产精华| 蜜桃91丨九色丨蝌蚪91桃色| 欧美午夜精品免费| 中文字幕一区二区三区在线不卡| 国产揄拍国内精品对白|