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

隨筆-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这里只有久久精品视频| 国产欧美一区二区三区久久人妖| 国产精品伊人日日| 欧美一进一出视频| 久久午夜电影网| 亚洲美女电影在线| 亚洲免费视频在线观看| 国产一区二区三区四区三区四| 快射av在线播放一区| 亚洲精品护士| 亚洲午夜电影网| 亚洲福利在线看| 亚洲视频视频在线| 亚洲精品国产欧美| 性高湖久久久久久久久| 亚洲视频www| 麻豆精品一区二区综合av| 午夜精品一区二区三区在线| 久久久中精品2020中文| 午夜久久一区| 欧美日韩国产另类不卡| 欧美激情1区2区| 黄色成人av| 久久精品夜色噜噜亚洲aⅴ| 亚洲一区二区三区精品在线观看| 久久男女视频| 久热精品视频在线观看一区| 欧美成年人网站| 亚洲另类春色国产| 免费的成人av| 欧美激情片在线观看| 在线观看国产精品网站| 久久永久免费| 亚洲国产综合在线| 亚洲欧美日韩一区在线| 一区二区三区视频观看| 欧美日韩综合另类| 亚洲午夜av电影| 亚洲第一福利视频| 国产精品黄页免费高清在线观看| 亚洲人被黑人高潮完整版| 红桃视频国产精品| 欧美在线观看网站| 亚洲一区一卡| 黄色日韩在线| 欧美国产精品va在线观看| 欧美激情精品久久久久久大尺度| 91久久久久久久久| 欧美视频在线观看| 久久人人爽爽爽人久久久| 亚洲精品影视在线观看| 午夜精品一区二区三区四区| 国产一区二区三区日韩| 欧美日韩精品在线播放| 欧美与欧洲交xxxx免费观看| 亚洲人成在线观看| 久久亚洲精品欧美| 亚洲欧美文学| 亚洲尤物在线| 一区二区日韩伦理片| 伊人蜜桃色噜噜激情综合| 亚洲一区二区在线视频 | 亚洲国产综合在线| 国产精品国产馆在线真实露脸 | 日韩视频专区| 欧美成人午夜激情在线| 久久精品女人的天堂av| 久久成人人人人精品欧| 亚洲综合国产| 亚洲女性裸体视频| 亚洲一级电影| 久久激情网站| 亚洲第一黄网| 欧美插天视频在线播放| 久久精品论坛| 欧美成人蜜桃| 亚洲精品一区二区三区樱花| 国产精品自在线| 国产亚洲精品自拍| 黄色工厂这里只有精品| 亚洲人在线视频| 亚洲午夜精品17c| 久久综合亚洲社区| 久久人人看视频| 亚洲人被黑人高潮完整版| 日韩午夜一区| 性欧美超级视频| 欧美日本高清| 国产伦精品一区二区三区免费| 国产精品亚洲综合一区在线观看| 国产亚洲精品aa| 亚洲视频久久| 久久综合九色综合久99| 欧美日韩伦理在线| 亚洲第一毛片| 另类激情亚洲| 亚洲一区二区在线看| 欧美国产视频在线| 国内精品伊人久久久久av影院| 中国av一区| 久久久www成人免费毛片麻豆| 久久久久久久国产| 欧美电影在线观看完整版| 在线一区二区三区四区| 亚洲免费视频成人| 老司机免费视频一区二区| 国产一区二区三区丝袜| 性欧美xxxx视频在线观看| aa级大片欧美| 国产日韩在线看片| 久久精品视频播放| 久久久精品国产免费观看同学| 国产精品久久9| 午夜天堂精品久久久久| 性色av香蕉一区二区| 国外成人免费视频| 欧美大尺度在线| 欧美日韩精品系列| 久久电影一区| 欧美va亚洲va香蕉在线| 99亚洲伊人久久精品影院红桃| 亚洲国产欧美日韩精品| 欧美日在线观看| 久久亚洲国产精品日日av夜夜| 久久一本综合频道| 中文高清一区| 欧美成人国产一区二区| 亚洲一区国产一区| 理论片一区二区在线| 亚洲永久免费av| 久久综合网hezyo| 亚洲图片在线观看| 美女网站在线免费欧美精品| 午夜精品电影| 欧美日韩妖精视频| 久久最新视频| 国产精品一二三视频| 亚洲毛片一区二区| 亚洲精品视频在线看| 久久精品国内一区二区三区| 亚洲欧美国产高清| 欧美日韩视频专区在线播放| 欧美激情片在线观看| 国语自产精品视频在线看| 亚洲一区在线观看免费观看电影高清| 亚洲国产日韩一区二区| 免费视频一区| 亚洲激情国产| 一本色道久久88亚洲综合88| 麻豆精品传媒视频| 国产精品区一区二区三| 亚洲一区二区免费| 久久久精品国产99久久精品芒果| 亚洲高清不卡在线观看| 国产午夜精品久久久久久免费视| 亚洲欧美日韩一区二区三区在线观看| 一区二区三区高清在线| 国产精品久久久久久福利一牛影视| 亚洲精品久久久蜜桃| 亚洲午夜一区二区三区| 国产九九视频一区二区三区| 欧美一区二区视频免费观看| 久久久久九九九九| 亚洲乱码国产乱码精品精可以看| 欧美黄色免费网站| 亚洲女人小视频在线观看| 久久久久久综合| 亚洲视频网在线直播| 在线看片第一页欧美| 欧美肉体xxxx裸体137大胆| 亚洲男人av电影| 久久亚洲国产精品一区二区 | 日韩一本二本av| 久久精品日韩| 亚洲在线视频网站| 亚洲二区视频在线| 国产有码一区二区| 欧美午夜大胆人体| 欧美日韩成人| 免费一级欧美片在线播放| 一区二区免费在线观看| 欧美高清成人| 欧美成人高清| 巨乳诱惑日韩免费av| 久久美女性网| 欧美成人精品一区二区| 久久久91精品| 亚洲电影免费观看高清完整版在线观看 | 亚洲精品免费在线| 好吊一区二区三区| 国产精品劲爆视频| 国产精品私拍pans大尺度在线| 欧美日本国产视频| 国产精品青草久久| 国产免费成人在线视频| 国内精品亚洲| 亚洲精品一区二区三区福利| 亚洲视频一区二区| 久久九九热免费视频| 亚洲欧洲在线播放|