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

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

?? bo7-1.c

?? 第七章到第十二章的代碼實現
?? C
?? 第 1 頁 / 共 2 頁
字號:
 /* bo7-1.c 圖的數組(鄰接矩陣)存儲(存儲結構由c7-1.h定義)的基本操作(20個) */
 int LocateVex(MGraph G,VertexType u)
 { /* 初始條件:圖G存在,u和G中頂點有相同特征 */
   /* 操作結果:若G中存在頂點u,則返回該頂點在圖中位置;否則返回-1 */
   int i;
   for(i=0;i<G.vexnum;++i)
     if(strcmp(u,G.vexs[i])==0)
       return i;
   return -1;
 }

 Status CreateFAG(MGraph *G)
 { /* 采用數組(鄰接矩陣)表示法,由文件構造沒有相關信息的無向圖G */
   int i,j,k;
   char filename[13];
   VertexType va,vb;
   FILE *graphlist;
   printf("請輸入數據文件名(f7-1.dat):");
   scanf("%s",filename);
   graphlist=fopen(filename,"r");
   fscanf(graphlist,"%d",&(*G).vexnum);
   fscanf(graphlist,"%d",&(*G).arcnum);
   for(i=0;i<(*G).vexnum;++i) /* 構造頂點向量 */
     fscanf(graphlist,"%s",(*G).vexs[i]);
   for(i=0;i<(*G).vexnum;++i) /* 初始化鄰接矩陣 */
     for(j=0;j<(*G).vexnum;++j)
     {
       (*G).arcs[i][j].adj=0; /* 圖 */
       (*G).arcs[i][j].info=NULL; /* 沒有相關信息 */
     }
   for(k=0;k<(*G).arcnum;++k)
   {
     fscanf(graphlist,"%s%s",va,vb);
     i=LocateVex(*G,va);
     j=LocateVex(*G,vb);
     (*G).arcs[i][j].adj=(*G).arcs[j][i].adj=1; /* 無向圖 */
   }
   fclose(graphlist);
   (*G).kind=AG;
   return OK;
 }

 Status CreateDG(MGraph *G)
 { /* 采用數組(鄰接矩陣)表示法,構造有向圖G */
   int i,j,k,l,IncInfo;
   char s[MAX_INFO],*info;
   VertexType va,vb;
   printf("請輸入有向圖G的頂點數,弧數,弧是否含其它信息(是:1,否:0): ");
   scanf("%d,%d,%d",&(*G).vexnum,&(*G).arcnum,&IncInfo);
   printf("請輸入%d個頂點的值(<%d個字符):\n",(*G).vexnum,MAX_NAME);
   for(i=0;i<(*G).vexnum;++i) /* 構造頂點向量 */
     scanf("%s",(*G).vexs[i]);
   for(i=0;i<(*G).vexnum;++i) /* 初始化鄰接矩陣 */
     for(j=0;j<(*G).vexnum;++j)
     {
       (*G).arcs[i][j].adj=0; /* 圖 */
       (*G).arcs[i][j].info=NULL;
     }
   printf("請輸入%d條弧的弧尾 弧頭(以空格作為間隔): \n",(*G).arcnum);
   for(k=0;k<(*G).arcnum;++k)
   {
     scanf("%s%s%*c",va,vb);  /* %*c吃掉回車符 */
     i=LocateVex(*G,va);
     j=LocateVex(*G,vb);
     (*G).arcs[i][j].adj=1; /* 有向圖 */
     if(IncInfo)
     {
       printf("請輸入該弧的相關信息(<%d個字符): ",MAX_INFO);
       gets(s);
       l=strlen(s);
       if(l)
       {
         info=(char*)malloc((l+1)*sizeof(char));
         strcpy(info,s);
         (*G).arcs[i][j].info=info; /* 有向 */
       }
     }
   }
   (*G).kind=DG;
   return OK;
 }

 Status CreateDN(MGraph *G)
 { /* 采用數組(鄰接矩陣)表示法,構造有向網G */
   int i,j,k,w,IncInfo;
   char s[MAX_INFO],*info;
   VertexType va,vb;
   printf("請輸入有向網G的頂點數,弧數,弧是否含其它信息(是:1,否:0): ");
   scanf("%d,%d,%d",&(*G).vexnum,&(*G).arcnum,&IncInfo);
   printf("請輸入%d個頂點的值(<%d個字符):\n",(*G).vexnum,MAX_NAME);
   for(i=0;i<(*G).vexnum;++i) /* 構造頂點向量 */
     scanf("%s",(*G).vexs[i]);
   for(i=0;i<(*G).vexnum;++i) /* 初始化鄰接矩陣 */
     for(j=0;j<(*G).vexnum;++j)
     {
       (*G).arcs[i][j].adj=INFINITY; /* 網 */
       (*G).arcs[i][j].info=NULL;
     }
   printf("請輸入%d條弧的弧尾 弧頭 權值(以空格作為間隔): \n",(*G).arcnum);
   for(k=0;k<(*G).arcnum;++k)
   {
     scanf("%s%s%d%*c",va,vb,&w);  /* %*c吃掉回車符 */
     i=LocateVex(*G,va);
     j=LocateVex(*G,vb);
     (*G).arcs[i][j].adj=w; /* 有向網 */
     if(IncInfo)
     {
       printf("請輸入該弧的相關信息(<%d個字符): ",MAX_INFO);
       gets(s);
       w=strlen(s);
       if(w)
       {
         info=(char*)malloc((w+1)*sizeof(char));
         strcpy(info,s);
         (*G).arcs[i][j].info=info; /* 有向 */
       }
     }
   }
   (*G).kind=DN;
   return OK;
 }

 Status CreateAG(MGraph *G)
 { /* 采用數組(鄰接矩陣)表示法,構造無向圖G */
   int i,j,k,l,IncInfo;
   char s[MAX_INFO],*info;
   VertexType va,vb;
   printf("請輸入無向圖G的頂點數,邊數,邊是否含其它信息(是:1,否:0): ");
   scanf("%d,%d,%d",&(*G).vexnum,&(*G).arcnum,&IncInfo);
   printf("請輸入%d個頂點的值(<%d個字符):\n",(*G).vexnum,MAX_NAME);
   for(i=0;i<(*G).vexnum;++i) /* 構造頂點向量 */
     scanf("%s",(*G).vexs[i]);
   for(i=0;i<(*G).vexnum;++i) /* 初始化鄰接矩陣 */
     for(j=0;j<(*G).vexnum;++j)
     {
       (*G).arcs[i][j].adj=0; /* 圖 */
       (*G).arcs[i][j].info=NULL;
     }
   printf("請輸入%d條邊的頂點1 頂點2(以空格作為間隔): \n",(*G).arcnum);
   for(k=0;k<(*G).arcnum;++k)
   {
     scanf("%s%s%*c",va,vb); /* %*c吃掉回車符 */
     i=LocateVex(*G,va);
     j=LocateVex(*G,vb);
     (*G).arcs[i][j].adj=(*G).arcs[j][i].adj=1; /* 無向圖 */
     if(IncInfo)
     {
       printf("請輸入該邊的相關信息(<%d個字符): ",MAX_INFO);
       gets(s);
       l=strlen(s);
       if(l)
       {
         info=(char*)malloc((l+1)*sizeof(char));
         strcpy(info,s);
         (*G).arcs[i][j].info=(*G).arcs[j][i].info=info; /* 無向 */
       }
     }
   }
   (*G).kind=AG;
   return OK;
 }

 Status CreateAN(MGraph *G)
 { /* 采用數組(鄰接矩陣)表示法,構造無向網G。算法7.2 */
   int i,j,k,w,IncInfo;
   char s[MAX_INFO],*info;
   VertexType va,vb;
   printf("請輸入無向網G的頂點數,邊數,邊是否含其它信息(是:1,否:0): ");
   scanf("%d,%d,%d",&(*G).vexnum,&(*G).arcnum,&IncInfo);
   printf("請輸入%d個頂點的值(<%d個字符):\n",(*G).vexnum,MAX_NAME);
   for(i=0;i<(*G).vexnum;++i) /* 構造頂點向量 */
     scanf("%s",(*G).vexs[i]);
   for(i=0;i<(*G).vexnum;++i) /* 初始化鄰接矩陣 */
     for(j=0;j<(*G).vexnum;++j)
     {
       (*G).arcs[i][j].adj=INFINITY; /* 網 */
       (*G).arcs[i][j].info=NULL;
     }
   printf("請輸入%d條邊的頂點1 頂點2 權值(以空格作為間隔): \n",(*G).arcnum);
   for(k=0;k<(*G).arcnum;++k)
   {
     scanf("%s%s%d%*c",va,vb,&w); /* %*c吃掉回車符 */
     i=LocateVex(*G,va);
     j=LocateVex(*G,vb);
     (*G).arcs[i][j].adj=(*G).arcs[j][i].adj=w; /* 無向 */
     if(IncInfo)
     {
       printf("請輸入該邊的相關信息(<%d個字符): ",MAX_INFO);
       gets(s);
       w=strlen(s);
       if(w)
       {
         info=(char*)malloc((w+1)*sizeof(char));
         strcpy(info,s);
         (*G).arcs[i][j].info=(*G).arcs[j][i].info=info; /* 無向 */
       }
     }
   }
   (*G).kind=AN;
   return OK;
 }

 Status CreateGraph(MGraph *G)
 { /* 采用數組(鄰接矩陣)表示法,構造圖G。算法7.1 */
   printf("請輸入圖G的類型(有向圖:0,有向網:1,無向圖:2,無向網:3): ");
   scanf("%d",&(*G).kind);
   switch((*G).kind)
   {
     case DG: return CreateDG(G); /* 構造有向圖 */
     case DN: return CreateDN(G); /* 構造有向網 */
     case AG: return CreateAG(G); /* 構造無向圖 */
     case AN: return CreateAN(G); /* 構造無向網 */
     default: return ERROR;
   }
 }

 void DestroyGraph(MGraph *G)
 { /* 初始條件: 圖G存在。操作結果: 銷毀圖G */
   int i,j;
   if((*G).kind<2) /* 有向 */
     for(i=0;i<(*G).vexnum;i++) /* 釋放弧的相關信息(如果有的話) */
     {
       for(j=0;j<(*G).vexnum;j++)
         if((*G).arcs[i][j].adj==1&&(*G).kind==0||(*G).arcs[i][j].adj!=INFINITY&&(*G).kind==1) /* 有向圖的弧||有向網的弧 */
           if((*G).arcs[i][j].info) /* 有相關信息 */
           {
             free((*G).arcs[i][j].info);
             (*G).arcs[i][j].info=NULL;
           }
     }
   else /* 無向 */
     for(i=0;i<(*G).vexnum;i++) /* 釋放邊的相關信息(如果有的話) */
       for(j=i+1;j<(*G).vexnum;j++)
         if((*G).arcs[i][j].adj==1&&(*G).kind==2||(*G).arcs[i][j].adj!=INFINITY&&(*G).kind==3) /* 無向圖的邊||無向網的邊 */
           if((*G).arcs[i][j].info) /* 有相關信息 */
           {
             free((*G).arcs[i][j].info);
             (*G).arcs[i][j].info=(*G).arcs[j][i].info=NULL;
           }
   (*G).vexnum=0;
   (*G).arcnum=0;
 }

 VertexType* GetVex(MGraph G,int v)
 { /* 初始條件: 圖G存在,v是G中某個頂點的序號。操作結果: 返回v的值 */
   if(v>=G.vexnum||v<0)
     exit(ERROR);
   return &G.vexs[v];
 }

 Status PutVex(MGraph *G,VertexType v,VertexType value)
 { /* 初始條件: 圖G存在,v是G中某個頂點。操作結果: 對v賦新值value */
   int k;
   k=LocateVex(*G,v); /* k為頂點v在圖G中的序號 */
   if(k<0)
     return ERROR;
   strcpy((*G).vexs[k],value);
   return OK;
 }

 int FirstAdjVex(MGraph G,VertexType v)
 { /* 初始條件: 圖G存在,v是G中某個頂點 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
岛国精品一区二区| 欧美老肥妇做.爰bbww| 国产91露脸合集magnet| 美国十次综合导航| 首页国产欧美久久| 日韩电影免费一区| 日本va欧美va瓶| 美女在线一区二区| 久久精品国产网站| 国产精品一区二区免费不卡| 国产麻豆精品视频| 成人18视频日本| 一本久久a久久免费精品不卡| 91在线国产福利| 日本韩国一区二区三区视频| 欧美性猛交xxxxxxxx| 欧美亚洲免费在线一区| 欧美精品在线视频| 欧美一区二区在线观看| 欧美r级在线观看| 国产欧美日本一区视频| 国产精品丝袜91| 一区二区高清视频在线观看| 午夜影院久久久| 免费观看日韩电影| 国产精品一区二区视频| 91色婷婷久久久久合中文| 欧美中文字幕久久| 日韩欧美一级在线播放| 国产亚洲一区二区三区在线观看 | 欧美日韩国产高清一区| 欧美福利电影网| 欧美人与禽zozo性伦| 日本一区二区成人| 91行情网站电视在线观看高清版| 精品午夜一区二区三区在线观看 | 国产精品88888| 99re热这里只有精品视频| 欧美丝袜丝交足nylons图片| 欧美一区国产二区| 国产精品视频一区二区三区不卡| 亚洲综合激情小说| 国内精品嫩模私拍在线| 色婷婷激情一区二区三区| 欧美成人a在线| 亚洲丝袜制服诱惑| 免费一级欧美片在线观看| 成人精品视频一区二区三区 | 亚洲最色的网站| 久久99热这里只有精品| 91麻豆免费视频| 2021久久国产精品不只是精品| 综合激情网...| 久久精品国产999大香线蕉| av高清久久久| 欧美成人精品二区三区99精品| 国产精品久久久久影院亚瑟 | 亚洲日本一区二区| 天天操天天色综合| 国产精品1区2区3区在线观看| 99久久婷婷国产综合精品电影 | 粉嫩一区二区三区性色av| 成人app在线观看| 欧美亚洲综合另类| 久久精品人人爽人人爽| 亚洲在线观看免费| 久久er精品视频| 97超碰欧美中文字幕| 91精品国产全国免费观看| 久久久久青草大香线综合精品| 一区二区三区四区乱视频| 精品亚洲porn| 欧美日韩精品是欧美日韩精品| 日韩欧美中文字幕一区| 亚洲国产一区视频| 国产成人av一区二区| 欧美日韩国产精品成人| 中日韩免费视频中文字幕| 丝袜亚洲另类欧美| 91丨九色丨国产丨porny| 欧美精品一区二区在线观看| 欧美精品一区二区三区高清aⅴ| 精品国产91乱码一区二区三区| 国产精品入口麻豆九色| 亚洲成av人片在www色猫咪| 伦理电影国产精品| 99精品欧美一区二区三区小说| 日韩欧美国产精品一区| 一区二区三区精密机械公司| 国产91丝袜在线播放| 日韩精品一区二区三区在线观看| 国产精品美女久久久久av爽李琼| 日本v片在线高清不卡在线观看| 99久久精品免费看| 久久精品欧美一区二区三区不卡 | 久久97超碰国产精品超碰| 色综合久久久久久久久久久| 国产午夜久久久久| 久久av资源网| 日韩一级完整毛片| 亚洲va国产天堂va久久en| 成人午夜激情在线| 久久久久久久电影| 久久精品国产亚洲高清剧情介绍 | 国产三级精品视频| 奇米综合一区二区三区精品视频| 91黄色免费观看| 亚洲免费成人av| proumb性欧美在线观看| 777xxx欧美| 免费xxxx性欧美18vr| 欧美日韩久久久| 亚洲第一成年网| 在线观看免费视频综合| 亚洲少妇最新在线视频| 99国产精品国产精品久久| 欧美韩国一区二区| 成人综合在线观看| 国产欧美一区二区精品性| 国产成人在线免费| 国产精品美女久久久久久久久久久| 国产综合久久久久久鬼色| 精品久久人人做人人爽| 精品一区二区三区免费视频| 精品欧美一区二区在线观看| 久久精品国产免费| 精品国偷自产国产一区| 国产一区二区在线观看视频| 亚洲精品在线电影| 老汉av免费一区二区三区| 日韩免费观看2025年上映的电影| 亚洲成年人影院| 91精品国模一区二区三区| 久久精品国产久精国产爱| 国产日韩精品一区| 99视频在线观看一区三区| 自拍视频在线观看一区二区| 色先锋资源久久综合| 亚洲成人精品影院| 欧美一级一级性生活免费录像| 久久不见久久见免费视频1| 久久久久久影视| 韩国在线一区二区| 亚洲欧洲精品成人久久奇米网| 97精品久久久久中文字幕| 亚洲国产欧美日韩另类综合| 制服丝袜av成人在线看| 国产精品 日产精品 欧美精品| 国产精品视频第一区| 一本大道久久精品懂色aⅴ| 亚洲bt欧美bt精品777| 日韩欧美一区二区久久婷婷| 国产在线国偷精品产拍免费yy| 中文字幕av一区二区三区免费看| 99久久综合精品| 亚洲成在线观看| 欧美videofree性高清杂交| 成人美女视频在线看| 亚洲高清视频在线| 精品国产91久久久久久久妲己| 国产黄色91视频| 视频精品一区二区| 国产日韩v精品一区二区| 在线欧美日韩国产| 另类综合日韩欧美亚洲| 国产精品久久久久影院亚瑟| 欧美日韩国产乱码电影| 狠狠久久亚洲欧美| 亚洲欧美区自拍先锋| 精品国产乱子伦一区| 色综合av在线| 韩国精品主播一区二区在线观看| 26uuu国产电影一区二区| 在线国产电影不卡| 国产麻豆视频精品| 亚洲乱码中文字幕| 欧美一级一级性生活免费录像| 成人黄色免费短视频| 美美哒免费高清在线观看视频一区二区| 国产精品美女视频| 精品日产卡一卡二卡麻豆| 欧美熟乱第一页| 成人性视频免费网站| 免费三级欧美电影| 国产精品污www在线观看| 久久亚洲免费视频| 欧美色成人综合| 不卡电影一区二区三区| 久久精品久久久精品美女| 一区二区国产盗摄色噜噜| 国产人妖乱国产精品人妖| 欧美午夜精品一区二区三区 | 精品视频在线视频| 成人黄色软件下载| 精品影视av免费| 麻豆精品视频在线观看视频| 亚洲一区二区三区激情| 国产精品久久综合| 久久亚洲影视婷婷| 日韩欧美美女一区二区三区|