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

隨筆-48  評(píng)論-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. 無(wú)向圖  3. 無(wú)向網(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<<"無(wú)向圖"<<endl;break;
  case UDN:cout<<"無(wú)向網(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<<"最小生成樹(shù)為"<<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>
            老司机67194精品线观看| 浪潮色综合久久天堂| 国产午夜精品一区二区三区视频 | 亚洲免费大片| 日韩午夜在线播放| 宅男精品视频| 久久99伊人| 久久夜色撩人精品| 欧美一二三区精品| 亚洲视频网在线直播| 亚洲一级一区| 欧美一区免费视频| 久久综合影视| 亚洲精品社区| 亚洲欧美在线看| 久久亚洲国产精品日日av夜夜| 欧美高清视频一区二区| 欧美日韩视频专区在线播放| 国产日韩精品一区二区| 亚洲国产欧美国产综合一区| 亚洲午夜在线| 免费不卡在线视频| a4yy欧美一区二区三区| 久久精品一区二区国产| 欧美日本网站| 激情欧美一区二区三区| 日韩一级成人av| 久久国产福利国产秒拍| 亚洲精品美女在线| 夜夜嗨一区二区| 久久中文字幕一区| 国产裸体写真av一区二区| 亚洲精品无人区| 久久久久国产精品一区三寸 | 亚洲视频一区| 美女图片一区二区| 亚洲网站在线观看| 欧美大片免费久久精品三p| 国产视频在线观看一区二区三区| 日韩视频在线一区二区三区| 久久久青草婷婷精品综合日韩| 99re亚洲国产精品| 猛男gaygay欧美视频| 国产一区二区你懂的| 亚洲欧美日韩在线观看a三区| 亚洲激情在线| 老司机67194精品线观看| 国精品一区二区三区| 亚洲欧美日韩久久精品| 日韩视频―中文字幕| 欧美电影在线观看完整版| 激情成人中文字幕| 久久久精品动漫| 校园春色国产精品| 国产欧美日韩免费| 亚洲欧美日韩一区在线| 99国产精品| 欧美手机在线| 亚洲一区二区黄| 9l国产精品久久久久麻豆| 欧美日韩一区自拍| 在线视频一区二区| 日韩午夜高潮| 欧美无乱码久久久免费午夜一区| 国产毛片精品视频| 欧美一区二区三区成人| 欧美小视频在线| 亚洲视频在线观看网站| 亚洲老板91色精品久久| 欧美日韩国产综合视频在线| 日韩亚洲不卡在线| 日韩五码在线| 国产精品hd| 欧美一区网站| 久久精品导航| 亚洲区国产区| 亚洲精品一区在线| 国产精品va在线| 久久精品国产99| 久久久久久久久久久久久9999| 在线观看一区二区精品视频| 欧美激情一级片一区二区| 欧美女人交a| 午夜精品理论片| 久久久激情视频| 一区二区毛片| 午夜亚洲性色福利视频| 在线免费观看欧美| 亚洲精品黄色| 国产欧美日韩在线| 欧美国产免费| 国产精品jvid在线观看蜜臀| 欧美中文字幕在线观看| 六月婷婷一区| 午夜激情综合网| 久久男女视频| 亚洲曰本av电影| 久久亚洲精品一区| 亚洲一区二区三区免费观看| 久久er99精品| 中文无字幕一区二区三区| 欧美在线影院| aaa亚洲精品一二三区| 欧美亚洲综合久久| 日韩一本二本av| 久久精品理论片| 亚洲免费婷婷| 欧美不卡视频| 久久人人爽人人爽爽久久| 欧美视频一区二区三区在线观看 | 亚洲国产精品成人综合| 国产精品久久久久久久久久免费看| 蜜桃av一区二区三区| 国产精品视频精品| 亚洲精品久久久久久久久久久| 国产欧美一区视频| 日韩一二三在线视频播| 亚洲欧洲精品一区| 久久久777| 久久精品视频在线看| 国产精品久久久久久久久久妞妞 | 另类亚洲自拍| 国产老肥熟一区二区三区| 精品91久久久久| 亚洲免费在线电影| 欧美jizzhd精品欧美巨大免费| 久久精品在线播放| 欧美久久综合| 欧美福利网址| 在线免费不卡视频| 久久精品视频免费观看| 久久精精品视频| 国产精品综合网站| 9i看片成人免费高清| 一区二区三区色| 欧美日韩高清在线| 亚洲久久在线| 中文亚洲欧美| 国产精品v日韩精品| 亚洲最新视频在线| 亚洲伊人网站| 国产精品高清一区二区三区| 99精品国产高清一区二区| 亚洲视频自拍偷拍| 欧美日韩国产精品一区| 99精品欧美一区| 午夜在线观看免费一区| 国产女主播在线一区二区| 久久www成人_看片免费不卡| 久久综合999| 亚洲电影免费观看高清完整版在线观看 | 亚洲午夜精品久久久久久app| 亚洲一区自拍| 国产日韩精品在线播放| 欧美一区二区三区喷汁尤物| 玖玖视频精品| 亚洲久久视频| 国产精品成人一区二区三区吃奶| 日韩一级在线观看| 久久国产夜色精品鲁鲁99| 黄色一区三区| 欧美理论在线播放| 亚洲男人的天堂在线aⅴ视频| 久久精品一区二区三区四区| 亚洲国产精品一区二区第四页av | 欧美性色aⅴ视频一区日韩精品| 亚洲自拍另类| 欧美成人亚洲成人| 亚洲午夜精品一区二区| 国产一区二区三区网站| 欧美激情第二页| 午夜免费在线观看精品视频| 欧美福利一区二区三区| 午夜精品影院| 亚洲精品日韩精品| 国产区日韩欧美| 欧美精品粉嫩高潮一区二区 | 亚洲国产精品免费| 亚洲一区日本| 亚洲福利在线观看| 国产精品人人爽人人做我的可爱| 亚洲影院免费观看| 久久精品国产欧美激情| 亚洲人成亚洲人成在线观看| 午夜精品视频在线观看| 亚洲娇小video精品| 国产日产欧美a一级在线| 欧美了一区在线观看| 久久精视频免费在线久久完整在线看| 亚洲精品自在在线观看| 免费成人你懂的| 欧美一区日韩一区| 中文日韩电影网站| 亚洲国产成人91精品| 国产婷婷色一区二区三区| 欧美日韩午夜剧场| 欧美sm视频| 久久这里只有| 久久国产精品第一页| 亚洲欧美国产一区二区三区|