青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-48  評論-259  文章-1  trackbacks-0

#include "iostream.h"
#include "fstream.h"
#include "SqStack.h"
#include "stdlib.h"


#define MAX 100000
#define  MAX_VERTEX_NUM 20     
typedef enum  {DG,DN,UDG,UDN} GraphKind;
typedef char VertexType;   
typedef struct {                                
 VertexType vexs[MAX_VERTEX_NUM];                      
 int        arcs[MAX_VERTEX_NUM][MAX_VERTEX_NUM];   
 int        vexnum,arcnum;                                      
 GraphKind  kind;                           
} MGraph;

int LocateVex(MGraph G,VertexType u)
{
  for(int i=0;i<G.vexnum&&G.vexs[i]!=u;i++);
  if(i==G.vexnum) return FALSE;
  else return i;
}
Status CreateGraph(MGraph &G)
{
  int n;
  cout<<" 0. 有向圖  1. 有向網(wǎng)、 "<<endl;
  cout<<" 2. 無向圖  3. 無向網(wǎng)   "<<endl; 
  cout<<"輸入你要建立的圖的類型:"<<endl;
  cin>>n;
  ifstream istrm;
  switch(n)
  {
  case 0:G.kind=DG;istrm.open("DGraph.txt");break;
  case 1:G.kind=DN;istrm.open("DNet.txt");break;
  case 2:G.kind=UDG;istrm.open("UDGraph.txt");break;
  case 3:G.kind=UDN;istrm.open("UDNet.txt");break;
  }
  istrm>>G.vexnum>>G.arcnum;
  int i,j,k,w;
  VertexType v1,v2;
  for(i=0;i<G.vexnum;i++) istrm>>G.vexs[i];
  if(n%2)
  {
    for(i=0;i<G.arcnum;i++)
  for(j=0;j<G.vexnum;j++)
   G.arcs[i][j]=MAX;
 for(k=0;k<G.arcnum;k++)
 { 
  istrm>>v1>>v2>>w;
  i=LocateVex(G,v1);
        j=LocateVex(G,v2);
  G.arcs[i][j]=w;
  if(n/2) G.arcs[j][i]=w;
 }

  }
  else
  {
    for(i=0;i<G.arcnum;i++)
  for(j=0;j<G.vexnum;j++)
   G.arcs[i][j]=0;
 for(k=0;k<G.arcnum;k++)
 { 
  istrm>>v1>>v2;
  i=LocateVex(G,v1);
        j=LocateVex(G,v2);
  G.arcs[i][j]=1;
  if(n/2) G.arcs[j][i]=1;
 }

  }
  return OK;
}
void OutPut(MGraph G)
{
  cout<<"該圖為";
  switch(G.kind)
  {
  case DG:cout<<"有向圖"<<endl;break;
  case DN:cout<<"有向網(wǎng)"<<endl;break;
  case UDG:cout<<"無向圖"<<endl;break;
  case UDN:cout<<"無向網(wǎng)"<<endl;break;
  }
  cout<<"頂點(diǎn)個(gè)數(shù)為"<<G.vexnum<<endl;
  cout<<"邊的條數(shù)為"<<G.arcnum<<endl;
  int i,j;
  if(G.kind/2)
  {
   for(i=0;i<G.vexnum;i++)
         for(j=0;j<i;j++)
   {
    if(G.arcs[i][j]!=0&&G.arcs[i][j]!=MAX)
    {
     cout<<G.vexs[i]<<" "<<G.vexs[j];
     if(G.kind%2) cout<<" "<<G.arcs[i][j];
     cout<<endl;
    }
   }
  }
  else
  {
    for(i=0;i<G.vexnum;i++)
         for(j=0;j<G.vexnum;j++)
   {
    if(G.arcs[i][j]!=0&&G.arcs[i][j]!=MAX)
    {
     cout<<G.vexs[i]<<" "<<G.vexs[j];
     if(G.kind%2) cout<<" "<<G.arcs[i][j];
     cout<<endl;
    }
   }
  }
}
void DFSTraverse(MGraph G)
{
  int visited[MAX_VERTEX_NUM],i;
  for(i=0;i<G.vexnum;i++)
   visited[i]=0;
  for(i=0;i<G.vexnum;i++)
  {
    if(!visited[i]) continue;
 visited[i]=1;
 cout<<G.vexs[i]<<" ";
  }
}
void MiniTree_PRIM(MGraph G,VertexType u)
{
  struct{
       VertexType adjvex;
       int lowcost;
  }closedge[MAX_VERTEX_NUM];
  int k=LocateVex(G,u);
  int i,j,min;
  for(j=0;j<G.vexnum;j++)
   if(j!=k) {closedge[j].adjvex=u;closedge[j].lowcost=G.arcs[k][j];}
  closedge[k].lowcost=0;
  cout<<"最小生成樹為"<<endl;
  for(i=1;i<G.vexnum;i++)
  { min=MAX;
    for(j=0;j<G.vexnum;j++)
 {   if(closedge[j].lowcost)
    if(closedge[j].lowcost<min) {k=j;min=closedge[j].lowcost;}
 }
 cout<<closedge[k].adjvex<<" "<<G.vexs[k]<<endl;
 closedge[k].lowcost=0;
 for(j=0;j<G.vexnum;j++)
  if(G.arcs[k][j]<closedge[j].lowcost)
  {
   closedge[j].adjvex=G.vexs[k];
   closedge[j].lowcost=G.arcs[k][j];
  }
  }
}
Status TopoSort(MGraph G)
{
  cout<<"拓?fù)渑判蛐蛄袨?;
  int indegree[MAX_VERTEX_NUM]={0};
  int i,j;
  VertexType e;
  for(i=0;i<G.vexnum;i++)//FindInDegree
   for(j=0;j<G.vexnum;j++)
   {
     if(G.arcs[j][i]) indegree[i]++;
   }
  SqStack S;
  InitStack(S);
  for(i=0;i<G.vexnum;i++)
  {
   if(!indegree[i]) {Push(S,G.vexs[i]);}
  }
  int count=0;
  //ofstream ostrm;
  //ostrm.open("TopoOrder.txt");
  while(!StackEmpty(S))
  {
    Pop(S,e);
 cout<<e<<" ";count++;
// ostrm<<e<<" ";
 i=LocateVex(G,e);
 for(j=0;j<G.vexnum;j++)
 {
  if(G.arcs[i][j])
  { 
   if(!(--indegree[j])) Push(S,G.vexs[j]);
  }
  
 }
  }

  if(count<G.vexnum) return ERROR;
  else return OK;
  cout<<endl;
}

Status TopoOrder(MGraph G,SqStack &T,int ve[])
{
  int indegree[MAX_VERTEX_NUM]={0};
  int i,j;
  VertexType e;
  for(i=0;i<G.vexnum;i++)//FindInDegree
   for(j=0;j<G.vexnum;j++)
   {
     if(G.arcs[j][i]!=MAX) indegree[i]++;
   }
  SqStack S;
  InitStack(S);
  for(i=0;i<G.vexnum;i++)
  {
   if(!indegree[i]) {Push(S,G.vexs[i]);}
  }
  int count=0;
  for(i=0;i<G.vexnum;i++)
   ve[i]=0;
  //ofstream ostrm;
  //ostrm.open("TopoOrder.txt");
  while(!StackEmpty(S))
  {
    Pop(S,e);Push(T,e);
    count++;
// ostrm<<e<<" ";
 i=LocateVex(G,e);
 for(j=0;j<G.vexnum;j++)
 {
  if(G.arcs[i][j]!=MAX)
  { 
   if(!(--indegree[j])) Push(S,G.vexs[j]);
   if(ve[i]+G.arcs[i][j]>ve[j]) {ve[j]=ve[i]+G.arcs[i][j];}
   
  }
  
 }
  }
   
  if(count<G.vexnum) return ERROR;
  else return OK;
  cout<<endl;
}
Status CriticalPath(MGraph G)
{
  SqStack T;
  InitStack(T);
  int i,j,k;
  int ee,el;
  int ve[MAX_VERTEX_NUM],vl[MAX_VERTEX_NUM];
  VertexType e;
  if(!TopoOrder(G,T,ve)) return ERROR;
 
  for(i=0;i<G.vexnum;i++)  vl[i]=ve[G.vexnum-1];
  while(!StackEmpty(T))
  {
    Pop(T,e);k=LocateVex(G,e);
 for(j=0;j<G.vexnum;j++)
 {
      if(G.arcs[k][j]!=MAX) 
    if(vl[j]-G.arcs[k][j]<vl[k]) vl[k]=vl[j]-G.arcs[k][j];
 }
  }
  //for(i=0;i<G.vexnum;i++) cout<<" "<<vl[i];exit(1);
  for(i=0;i<G.vexnum;i++)
   for(j=0;j<G.vexnum;j++)
     if(G.arcs[i][j]!=MAX)
  {
    ee=ve[i];el=vl[j]-G.arcs[i][j];
    char tag=(ee==el)?'*':'+';
    cout<<G.vexs[i]<<" "<<G.vexs[j]<<" "<<G.arcs[i][j]<<" "<<tag<<endl;
  }
   return OK;
  
}
void ShortestPath_DIJ(MGraph G,VertexType u)
{
  int v0=LocateVex(G,u);
  bool final[MAX_VERTEX_NUM];
  int P[MAX_VERTEX_NUM],D[MAX_VERTEX_NUM];
  int i,j,min,v;
  for(i=0;i<G.vexnum;i++)
  {
   final[i]=FALSE;D[i]=G.arcs[v0][i];
   if(G.arcs[v0][i]!=MAX) P[i]=v0;
   else P[i]=MAX;
  }
  final[v0]=TRUE;
  P[v0]=v0;
  D[v0]=0;
  for(i=1;i<G.vexnum;i++)
  {
    min=MAX;
 for(j=0;j<G.vexnum;j++)
  if(!final[j])
   if(D[j]<min) {v=j;min=D[j];}
 final[v]=TRUE;
 for(j=0;j<G.vexnum;j++)
  if(!final[j]&&(min+G.arcs[v][j]<D[j]))
  {
    D[j]=min+G.arcs[v][j];
    P[j]=v;
  }//if
  }//for
  for(i=0;i<G.vexnum;i++)
  {
    cout<<G.vexs[i]<<" ";
 j=i;
 while(j!=v0)
 {
   j=P[j];
   cout<<G.vexs[j]<<" ";
  
 }
 cout<<D[i]<<endl;
  }
}//DIJ

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久九九国产精品怡红院| 久久久天天操| 午夜在线观看欧美| 亚洲国产精品久久久久秋霞影院| 这里是久久伊人| 欧美国产综合视频| 亚洲精品国产精品乱码不99按摩| 久久久伊人欧美| 欧美一级欧美一级在线播放| 国产精品捆绑调教| 欧美一区二区三区免费观看| 亚洲视频免费看| 亚洲国产免费| 欧美va亚洲va香蕉在线| 亚洲国产精品传媒在线观看| 美女脱光内衣内裤视频久久影院| 久久精品国产免费观看| 黄色在线一区| 欧美成人激情视频| 欧美成人蜜桃| 一区二区精品| 亚洲一区二区免费| 国产日韩欧美日韩| 老色批av在线精品| 欧美成人在线免费观看| 一区二区三区国产盗摄| 一区二区三区四区在线| 国产欧美日韩在线视频| 久久婷婷综合激情| 欧美电影在线| 亚洲欧美一区二区三区在线| 欧美一区视频在线| 亚洲第一福利在线观看| 亚洲精品乱码久久久久久蜜桃91| 欧美三区视频| 狼狼综合久久久久综合网| 欧美不卡一区| 午夜精品久久久| 久久综合一区二区| 中文网丁香综合网| 欧美中文字幕在线视频| 91久久精品国产91久久性色| 999亚洲国产精| 国模 一区 二区 三区| 亚洲国产91精品在线观看| 国产精品igao视频网网址不卡日韩| 欧美在线视频在线播放完整版免费观看| 久久精品人人做人人爽电影蜜月| 日韩视频在线免费观看| 午夜视频在线观看一区二区| 亚洲精品久久嫩草网站秘色| 亚洲专区一区| 一本久道久久综合婷婷鲸鱼| 久久大逼视频| 亚洲欧美一区二区三区久久 | 欧美顶级大胆免费视频| 亚洲一区二区三区高清不卡| 久久精品女人的天堂av| 亚洲素人在线| 免费日韩成人| 久久一区中文字幕| 国产精品久久二区二区| 亚洲盗摄视频| 激情欧美一区二区三区| 亚洲一级在线| 9久草视频在线视频精品| 久久久久久九九九九| 亚洲影院免费| 欧美日韩国产在线看| 欧美激情五月| 极品日韩久久| 小黄鸭精品aⅴ导航网站入口| 一本大道久久精品懂色aⅴ| 久久久久免费视频| 久久本道综合色狠狠五月| 一本色道久久综合一区| 亚洲第一精品夜夜躁人人爽| 性欧美8khd高清极品| 亚洲欧美综合精品久久成人| 欧美日韩视频一区二区| 亚洲国产视频一区二区| 亚洲国产欧美一区二区三区同亚洲| 欧美一区二区三区在线| 先锋影音一区二区三区| 国产精品美女黄网| 亚洲视频在线观看三级| 亚洲私人黄色宅男| 欧美日韩一区三区| 洋洋av久久久久久久一区| aⅴ色国产欧美| 欧美日本中文字幕| 亚洲免费av观看| 中文无字幕一区二区三区| 欧美日韩喷水| 中文av一区二区| 性亚洲最疯狂xxxx高清| 国产日韩欧美亚洲| 欧美有码视频| 欧美高清视频一区二区三区在线观看| 亚洲福利国产| 欧美黄色网络| 一本色道久久综合| 欧美一区二区免费视频| 国产一区999| 久久久久欧美精品| 亚洲高清自拍| 亚洲影院色无极综合| 国产欧美日本一区二区三区| 久久av红桃一区二区小说| 久久全国免费视频| 亚洲欧洲美洲综合色网| 欧美日韩一区二区三区免费看| 宅男噜噜噜66国产日韩在线观看| 亚洲免费在线视频一区 二区| 国产欧美日韩一区二区三区在线观看 | 欧美精品自拍偷拍动漫精品| 夜色激情一区二区| 久久国产精品黑丝| 最新日韩精品| 国产精品视频不卡| 久久综合久色欧美综合狠狠 | 欧美jizzhd精品欧美巨大免费| 亚洲国产一区二区精品专区| 欧美日韩精品久久| 久久av二区| 99精品国产福利在线观看免费| 欧美专区在线观看| 日韩视频一区二区在线观看 | 在线日韩中文字幕| 欧美特黄一级| 蜜桃精品久久久久久久免费影院| 中文在线不卡| 亚洲高清中文字幕| 久久激情五月丁香伊人| 欧美日韩免费网站| 久久精品一区中文字幕| 99视频精品免费观看| 蜜桃视频一区| 午夜欧美精品| 日韩亚洲精品电影| 在线观看日韩国产| 国产欧美日韩在线| 欧美体内she精视频在线观看| 久久久久欧美| 午夜视频一区| 亚洲午夜免费视频| 亚洲精品国产精品国产自| 久久在线免费观看| 香蕉视频成人在线观看| 亚洲麻豆视频| 悠悠资源网亚洲青| 国产色婷婷国产综合在线理论片a| 欧美精品不卡| 免费在线成人av| 久久精品国产久精国产爱| 亚洲香蕉在线观看| 一本到高清视频免费精品| 亚洲国产影院| 欧美大片在线观看一区二区| 久久精品盗摄| 欧美在线视频不卡| 欧美一级精品大片| 亚洲欧美精品伊人久久| 在线亚洲欧美视频| 99热这里只有精品8| 亚洲欧洲另类国产综合| 亚洲国产日韩欧美在线99| 在线观看日产精品| 激情综合久久| 黄色日韩网站| 伊人天天综合| 尤物yw午夜国产精品视频| 国内视频一区| 红桃视频国产精品| 一色屋精品视频在线看| 在线日韩av| 亚洲精品在线视频| 一本色道久久88综合亚洲精品ⅰ | 伊人久久亚洲美女图片| 红桃视频亚洲| 亚洲激情小视频| 99精品视频免费| 亚洲视频一区二区在线观看 | 午夜精品一区二区三区电影天堂| 亚洲视频图片小说| 亚洲欧美资源在线| 久久激情视频久久| 美国十次了思思久久精品导航| 能在线观看的日韩av| 欧美国产日韩一区二区三区| 欧美精品啪啪| 国产精品任我爽爆在线播放| 国产乱码精品一区二区三区不卡 | 国产精品国产精品| 国产欧美精品日韩| 亚洲大片av| 亚洲一区二区三区免费在线观看| 午夜综合激情| 欧美黄色免费网站| 亚洲免费黄色|