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

隨筆-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>
            久久国产黑丝| 久久免费视频在线观看| 欧美激情成人在线视频| 欧美成人在线免费观看| 久久精品中文字幕一区二区三区| 中国亚洲黄色| 欧美一区国产一区| 国产综合欧美在线看| 久久精品国产亚洲精品| 欧美一区综合| 模特精品在线| 免费观看一区| 欧美成人精品影院| 久久精品成人一区二区三区| 国产亚洲精品久久久久动| 欧美影院久久久| 亚洲国产精品一区二区www| 亚洲一区二区久久| 国产欧美精品国产国产专区| 亚洲性感美女99在线| 国产人成一区二区三区影院| 久久久久网址| 蜜桃av久久久亚洲精品| 一本久道久久久| 久久久久久久999精品视频| 欧美三级网址| 一区二区在线视频播放| 亚洲精选视频免费看| 久久综合国产精品台湾中文娱乐网| 亚洲天堂黄色| 亚洲丰满少妇videoshd| 韩日欧美一区二区三区| 国产精品第一区| 欧美视频一区| 欧美片在线播放| 美女精品自拍一二三四| 久久久噜噜噜久久人人看| 国产精品国产三级国产aⅴ入口 | aaa亚洲精品一二三区| 久久久久久久一区二区三区| 国产精品剧情在线亚洲| 亚洲一区影院| 亚洲精品免费一二三区| 一区二区三区视频在线观看| 亚洲中午字幕| 中文欧美字幕免费| 亚洲香蕉伊综合在人在线视看| 一区二区三区黄色| 亚洲专区在线视频| 亚洲欧美日韩在线高清直播| 欧美综合国产| 欧美顶级大胆免费视频| 欧美国产日韩免费| 夜夜嗨av一区二区三区四季av| 99天天综合性| 欧美专区在线播放| 亚洲欧美日韩国产中文| 国内精品久久久久久久影视蜜臀| 久久久久久午夜| 美女精品自拍一二三四| 亚洲天堂网站在线观看视频| 久久精品成人| 午夜精品久久久久久久99黑人| 亚洲免费影院| 亚洲欧美色婷婷| a91a精品视频在线观看| 免费观看亚洲视频大全| 亚洲人体影院| 久久婷婷亚洲| 国产日韩欧美成人| 亚洲永久精品大片| 亚洲国产一区二区三区a毛片| 亚洲国产精品日韩| 国产精品亚洲成人| 日韩亚洲精品在线| 亚洲国产精品成人久久综合一区| 欧美一区精品| 另类尿喷潮videofree| 欧美在线视频免费| 欧美性大战久久久久| 女女同性精品视频| 国产一区二区三区在线观看视频| 一本大道久久a久久综合婷婷 | 国产视频在线观看一区| 欧美wwwwww| 久久av一区二区| 国产精品亚洲美女av网站| 久久久久久自在自线| 欧美在线首页| 激情综合自拍| 欧美激情bt| 欧美日韩久久精品| 亚洲制服av| 免费人成精品欧美精品| 黄色日韩网站| 亚洲激情在线激情| 久久国产精品久久久久久电车| 欧美日韩一区二区在线视频| 亚洲国产精品999| 久久久国产午夜精品| 久久久精品性| 亚洲精品之草原avav久久| 欧美激情中文字幕乱码免费| 一区二区三区精品视频| 蜜桃久久精品乱码一区二区| 日韩视频在线免费观看| 欧美一区二区三区四区在线观看地址| 国产亚洲激情视频在线| 亚洲国产高清自拍| 国产欧美精品xxxx另类| 一本色道久久88综合亚洲精品ⅰ| 狂野欧美性猛交xxxx巴西| 欧美成人第一页| 久久精品91| 欧美午夜影院| 91久久久精品| 亚洲国产天堂久久综合网| 亚洲一区二区av电影| 亚洲国产日韩精品| 亚洲一区二区三区在线视频| 欧美午夜精品电影| 小黄鸭精品密入口导航| 91久久在线| 一区二区三区在线观看国产| 欧美日精品一区视频| 久久久国产精品一区二区三区| 99热免费精品| 亚洲毛片在线观看| 国产精品欧美精品| 欧美精品一区二区精品网| 免费不卡在线视频| 欧美日韩精品久久久| 亚洲国产精品成人久久综合一区| 国语精品一区| 欧美成人精品一区二区| 亚洲一二三区视频在线观看| 久久久久久久精| 国产视频观看一区| 亚洲无线视频| 久久久久久久久一区二区| 亚洲承认在线| 国产精品久线观看视频| 香蕉久久精品日日躁夜夜躁| 欧美成人tv| 性8sex亚洲区入口| 亚洲国产成人av在线| 亚洲国产日韩一区| 欧美成人一区二区三区| 亚洲全部视频| 午夜精品福利一区二区蜜股av| 欧美一区二区在线免费播放| 久久久噜噜噜久久中文字免| 欧美国产丝袜视频| 国产精品国产三级国产专播品爱网| 国产精品日韩在线| 亚洲靠逼com| 欧美黄色片免费观看| 国产视频观看一区| 欧美午夜一区二区福利视频| 六月婷婷久久| 久久亚洲综合| 欧美在线综合| 亚洲国产成人tv| 夜夜爽www精品| 合欧美一区二区三区| 欧美激情一区二区三区高清视频| 国产精品久久夜| 亚洲一区二区少妇| 中文日韩电影网站| 亚洲综合三区| 亚洲免费小视频| 先锋影音国产精品| 欧美一区国产一区| 99pao成人国产永久免费视频| 免费日韩成人| 精品99一区二区三区| 欧美一级一区| 亚洲主播在线观看| 欧美午夜激情小视频| 亚洲一区二区伦理| 一区二区视频在线观看| 亚洲免费av电影| 欧美精品在线极品| 亚洲黄一区二区三区| 亚洲激情视频在线| 亚洲午夜精品视频| 久久激情一区| 欧美人与性动交α欧美精品济南到| 欧美日韩在线高清| 在线观看欧美日韩| 欧美成在线视频| 久久av在线看| 国产精品大片| 亚洲永久视频| 米奇777在线欧美播放| 一本到12不卡视频在线dvd| 久久精选视频| 国产无一区二区| 亚洲视频在线播放| 亚洲国产综合91精品麻豆|