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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? graph.cpp

?? 這是c++版本的數據結構
?? CPP
字號:
//graph.cpp
#include<iostream>
#include "graph.h"//引入頭文件
 
/*
 *前置條件:圖不存在
 *輸    入:無 
 *功    能:圖的初始化
 *輸    出:無
 *后置條件:得到一個有向圖
 */
template <class T>
ALGraph<T>::ALGraph(T a[ ], int n, int e)
{
    arcNum = e;                             //邊數
	vertexNum=n;                            //頂點數
    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++)           //依次輸入每一條邊,并在相應邊表中插入結點
    { 
		cout<<"請輸入邊所依附的兩個頂點的序號";
		cin>>i>>j;                         //輸入邊所依附的兩個頂點的序號
        ArcNode *s=new ArcNode; s->adjvex=j;  //生成一個邊表結點s
	    s->next=adjlist[i].firstedge;      //將結點s插入到結點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)                                              //循環刪除
	{
	  adjlist[i].firstedge=p->next;
	  delete p;                                                 //釋放結點空間
      p=adjlist[i].firstedge;
	}
  }
}
/*   
 *前置條件:圖已存在
 *輸    入:頂點i
 *功    能:輸出圖中頂點i的數據信息
 *輸    出:圖中頂點i的數據信息
 *后置條件:圖保持不變
 */
template <class T>
T ALGraph<T>::GetVex(int i)
{
	if ( i>vertexNum || i<0 ) throw "輸入頂點的位置不正確"; //頂點i不存在則拋出異常
	return adjlist[i].vertex;                               //返回第i個頂點的數據域  
}

/*
 *前置條件:圖已存在
 *輸    入:頂點i
 *功    能:將圖中頂點i的數據域置為value
 *輸    出:無
 *后置條件:圖保持不變
 */
template <class T>
void ALGraph<T>::PutVex(int i, T value)
{
	if ( i>vertexNum || i<0 ) throw "輸入頂點的位置不正確"; //頂點i不存在則拋出異常
	adjlist[i].vertex = value;                              //第i個頂點的數據域置為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++;                                            //頂點數加1
	VertexNode<T> tempvertex;
	tempvertex.vertex = value;
	tempvertex.firstedge = NULL;
	adjlist[i] = tempvertex;  	                    //第i個頂點的數據域置為value	
}
/*   
 *前置條件:圖已存在
 *輸    入:頂點i 
 *功    能:在圖中刪除頂點i 
 *輸    出:如果刪除不成功,拋出異常
 *后置條件:如果刪除成功,圖中減少了一個頂點,相應頂點所建立的邊也消去
 */
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;                                //生成一個邊表結點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結點
		}
		s=adjlist[i].firstedge;
		adjlist[i].firstedge=NULL;
		delete s;
	}
	for (k=i; k<vertexNum; k++)
	{ 		
	   adjlist[k]=adjlist[k+1];             //存儲頂點信息       
	} 
   vertexNum--;                             //頂點數減1
   for (k=0; k<vertexNum; k++)
	if( adjlist[k].firstedge != NULL )
	{
		s=adjlist[k].firstedge;                //將結點s插入到結點i的邊表的表頭
		while(s!=NULL)
		{
			if(s->adjvex > i)                  //搜索i結點
				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;      //生成一個邊表結點s
	s->next=adjlist[i].firstedge;             //將結點s插入到結點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出發深度優先遍歷圖
 *輸    出:圖中頂點的一個線性排列
 *后置條件:圖保持不變
 */
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出發廣度優先遍歷圖
 *輸    出:圖中頂點的一個線性排列
 *后置條件:圖保持不變
 */
template <class T>
void ALGraph<T>::BFSTraverse(int v)
{
  if ( v>vertexNum) throw "位置";                           //頂點輸入錯誤則拋出異常
  int front,rear,j;
  ArcNode * p;                                              //生成一個邊表結點p
  int Q[MaxSize];
  front=rear=-1;                                            //初始化隊列, 假設隊列采用順序存儲且不會發生溢出
  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一区二区三区免费野_久草精品视频
久久品道一品道久久精品| 欧美午夜片在线看| 国产无人区一区二区三区| 极品尤物av久久免费看| 久久九九影视网| 国产成人精品一区二区三区四区| 国产婷婷色一区二区三区四区| 国产成人免费在线| 亚洲欧美一区二区久久 | 精品理论电影在线观看| 精品一区二区三区免费| 日本一区二区三级电影在线观看 | 中文字幕在线不卡一区| 91欧美一区二区| 图片区小说区区亚洲影院| 欧美一区2区视频在线观看| 国产精品一区三区| 日韩一区二区不卡| 亚洲福利一二三区| 成年人国产精品| 国产一区二区伦理片| 夜夜嗨av一区二区三区中文字幕| 久88久久88久久久| av网站一区二区三区| 久久综合九色欧美综合狠狠| 91精品国产91久久久久久最新毛片 | 欧美一级黄色片| 一区二区三区在线免费| 色综合色综合色综合色综合色综合| 日韩综合一区二区| 中文字幕制服丝袜一区二区三区| 国产精品乱码一区二三区小蝌蚪| 精品少妇一区二区三区免费观看| 欧美tickling网站挠脚心| 国产亚洲一区字幕| 国产精品一区二区在线观看网站| 欧美成人官网二区| 激情成人综合网| 精品国产不卡一区二区三区| 极品少妇xxxx精品少妇偷拍| 久久伊人蜜桃av一区二区| 国产在线精品一区二区不卡了| 精品国产91洋老外米糕| 韩国av一区二区三区四区| 久久先锋影音av鲁色资源网| 国产精品一区一区三区| 国产精品三级视频| 色婷婷一区二区| 亚洲自拍欧美精品| 在线播放国产精品二区一二区四区| 日韩精品三区四区| 日韩一区二区电影在线| 国产成人亚洲综合色影视| 国产精品进线69影院| 色综合久久66| 日韩福利电影在线观看| 久久网站最新地址| 色综合一个色综合| 麻豆91免费观看| 日韩欧美一区二区三区在线| 国产精品77777| 一区二区三区四区不卡在线| 91麻豆精品国产91久久久久久| 美女在线视频一区| 国产精品高潮呻吟| 欧美在线视频全部完| 久久国产婷婷国产香蕉| 中文字幕一区免费在线观看| 欧美日韩专区在线| 国产在线一区二区| 亚洲成人黄色小说| 中文成人综合网| 51久久夜色精品国产麻豆| 国产不卡在线视频| 爽爽淫人综合网网站| 亚洲国产精品二十页| 欧美日韩高清一区二区三区| 成人小视频免费观看| 美女视频免费一区| 亚洲专区一二三| 国产欧美日韩综合精品一区二区| 欧美日韩免费视频| 91视频免费看| 国产激情一区二区三区| 丝袜美腿成人在线| 尤物在线观看一区| 国产精品国产三级国产aⅴ中文 | 99国产麻豆精品| 久久精品国产澳门| 亚洲一区在线视频| 中文字幕日韩欧美一区二区三区| 26uuu亚洲综合色欧美| 在线成人高清不卡| 欧美吻胸吃奶大尺度电影| 99久久精品免费| 国产成人免费在线观看| 久久草av在线| 日韩电影在线观看网站| 亚洲一卡二卡三卡四卡无卡久久| 国产精品色哟哟| 久久久另类综合| 日韩精品一区二区三区视频| 欧美久久久久久久久久| 在线观看国产一区二区| 一本到三区不卡视频| 91香蕉视频在线| av在线一区二区| 成人avav影音| av欧美精品.com| 91啪亚洲精品| 91色porny在线视频| 成人免费看片app下载| 成人国产精品免费网站| 成熟亚洲日本毛茸茸凸凹| 成人小视频免费观看| 成人h动漫精品一区二区| 成人h动漫精品一区二区| www.亚洲国产| 成人h动漫精品一区二区| 99精品视频免费在线观看| caoporm超碰国产精品| 99精品欧美一区| 欧美系列日韩一区| 欧美日韩在线观看一区二区| 欧美年轻男男videosbes| 欧美一区二区成人6969| 欧美精品一区二区三区久久久 | 欧美疯狂性受xxxxx喷水图片| 欧美视频精品在线观看| 欧美军同video69gay| 日韩欧美国产麻豆| 国产视频视频一区| 亚洲男同性视频| 天天综合日日夜夜精品| 精品写真视频在线观看| 成人妖精视频yjsp地址| 一本色道a无线码一区v| 欧美一区二区在线视频| 久久影院视频免费| 亚洲视频一二区| 蜜臀av一级做a爰片久久| 国产成人在线免费观看| 91黄色免费观看| 日韩欧美一区电影| 中文字幕av资源一区| 亚洲国产精品久久一线不卡| 美女爽到高潮91| 99国产精品99久久久久久| 欧美日韩不卡一区| 国产清纯在线一区二区www| 亚洲激情五月婷婷| 黄色资源网久久资源365| 91视频你懂的| 精品国产乱码久久久久久蜜臀 | 欧美日韩午夜在线视频| 亚洲精品一区二区三区四区高清| 成人免费在线视频观看| 天天影视涩香欲综合网| 风间由美一区二区三区在线观看| 欧美制服丝袜第一页| 国产夜色精品一区二区av| 亚洲成av人片在线观看无码| 国产91综合一区在线观看| 欧美日韩久久久久久| 日本一二三不卡| 日本免费新一区视频| 91色porny| 国产亚洲人成网站| 日本成人在线一区| 欧美亚洲动漫另类| 综合激情成人伊人| 国产精品一区二区视频| 欧美乱妇20p| 一区二区三区在线播放| 成人免费黄色在线| 久久久精品影视| 欧美bbbbb| 欧美精品色综合| 一区二区三区免费观看| 99在线精品免费| 国产精品美女一区二区三区| 美女视频第一区二区三区免费观看网站| 97精品久久久久中文字幕| 亚洲精品一区二区三区蜜桃下载| 日韩精品电影一区亚洲| 91久久精品网| 亚洲综合区在线| 91色综合久久久久婷婷| 亚洲欧洲日韩一区二区三区| 国产aⅴ综合色| www国产精品av| 久久成人免费网| 欧美xxxxxxxxx| 久久99精品一区二区三区三区| 日韩一区二区三区免费看 | 亚洲免费视频成人| 91麻豆成人久久精品二区三区| 国产精品三级av在线播放| 国产综合久久久久影院| 日韩欧美激情四射|