下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第C語言鄰接表建立圖詳解scanf_s("%d%d",v1,v2);
ENode*p1=(ENode*)malloc(sizeof(ENode));//為新建的邊申請空間
p1-ivex=v2;//該邊指向的節(jié)點
//頭插法建立
p1-next_edge=pG-vexs[v1].fidt_edge;
pG-vexs[v1].fidt_edge=p1;
returnpG;
intmain()
while(~scanf_s("%d%d",v,e))
if(v==0e==0)
break;
LGraph*pG;
pG=create();
return0;
無向圖
在代碼的建立鏈表的地方變成
//建立鏈表
for(inti=0;i++i)
intv1,v2;
scanf_s("%d%d",v1,v2);
ENode*p1=(ENode*)malloc(sizeof(ENode));//為新建的邊申請空間
p1-ivex=v2;//該邊指向的節(jié)點
//頭插法建立
p1-next_edge=pG-vexs[v1].fidt_edge;
pG-vexs[v1].fidt_edge=p1;
//另一條邊
ENode*p2=(ENode*)malloc(sizeof(ENode));//為新建的邊申請空間
p2-ivex=v1;//該邊指向的節(jié)點
//頭插法建立
p2-next_edge=pG-vexs[v2].fidt_edge;
pG-vexs[v2].fidt_edge=p2;
鄰接表存圖進行拓撲排序
#includestdio.h
#includestdlib.h
#includestring.h
#includestack
usingnamespacestd;
#definemaxn200
intv,e;
//表結點
typedefstruct_Enode
intivex;//該邊所指向的節(jié)點位置
struct_Enode*next_edge;//指向下一條邊
}ENode,*PENode;
//頭結點
typedefstruct_VNode
intdata;
intindegree;//記錄定點的入度
ENode*fidt_edge;
}VNode;
//鄰接表
typedefstruct_LGraph
intvex_num;//點的數(shù)量
intedg_num;//邊的數(shù)量
VNodevexs[maxn];//一維數(shù)組存表頭節(jié)點
}LGraph;
LGraph*create()
LGraph*pG;
pG=(LGraph*)malloc(sizeof(LGraph));
memset(pG,0,sizeof(LGraph));
pG-vex_num=v;//頂點數(shù)
pG-edg_num=e;//邊數(shù)
for(inti=0;i++i)//初始化定點表的指針域為空
pG-vexs[i].fidt_edge=NULL;
for(inti=0;i++i)
intv1,v2;
scanf_s("%d%d",v1,v2);
ENode*p1=(ENode*)malloc(sizeof(ENode));//為新建的邊申請空間
p1-ivex=v2;//該邊指向的節(jié)點
//頭插法建立
p1-next_edge=pG-vexs[v1].fidt_edge;
pG-vexs[v1].fidt_edge=p1;
returnpG;
voidTopSort(LGraph*pG)
stackint
intcount,k,i;
ENode*p;
for(inti=0;i++i)//記錄各個頂點的入度
//遍歷整個鄰接表,如果表結點的值為i,則i對應的頭結點的入度加1
p=pG-vexs[i].fidt_edge;//獲得其指向的第一條邊
while(p)
pG-vexs[p-ivex].indegree++;//該邊表存的位置對應的頭結點的入度數(shù)量加1
p=p-next_edge;
//將入度為0的壓入棧中
for(inti=0;i++i)
if(pG-vexs[i].indegree==0)s.push(i);
count=0;//對輸出的頂點計數(shù)
while(!s.empty())
intk=s.top();//取出
s.pop();
++count;
//與k節(jié)點相鄰的節(jié)點的入度減1
for(p=pG-vexs[k].fidt_edge;p;p=p-next_edge)
intto;
to=p-ivex;
pG-vexs[to].indegree--;
//減為0的話就壓入棧中
if(pG-vexs[to].indegree==0)
s.push(to);
if(countpG-vex_num)
printf("NO\n");
else
printf("YES\n");
intmain()
while(~scanf_s("%d%d",v,e))
if(v=
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 統(tǒng)編版2025-2026學年語文四年級第一學期期末質量檢測練習卷(含答案)
- 湖南省岳陽市汨羅市2025-2026學年八年級上學期1月期末生物試題(無答案)
- 河南省駐馬店市泌陽縣2025-2026學年八年級上學期1月期末考試歷史試卷答案
- 2025-2026學年一年級(上)期末游戲化測試語文試卷(附參考答案)
- 五年級題目及答案
- 文件筐測試題及答案
- 2026年小學語文模擬沖刺押題卷
- 誠實做事的演講稿
- 冀教版三年級上冊數(shù)學第二單元-兩、三位數(shù)乘一位數(shù)-測試卷及答案(奪冠系列)
- 高中高二下學期地理期末考試試題答案解析
- 蘇教版高中化學必修二知識點
- 2024年國家公務員考試國考中國人民銀行結構化面試真題試題試卷及答案解析
- 2025年中考語文一輪復習:民俗類散文閱讀 講義(含練習題及答案)
- 高中數(shù)學選擇性必修一課件第一章 空間向量與立體幾何章末復習(人教A版)
- 標準商品房買賣合同文本大全
- LY/T 3408-2024林下經濟術語
- 2025年湖南邵陽市新邵縣經濟開發(fā)區(qū)建設有限公司招聘筆試參考題庫附帶答案詳解
- 2023-2024學年八年級(上)期末數(shù)學試卷
- DB33T 1238-2021 智慧燈桿技術標準
- ICH《M10:生物分析方法驗證及樣品分析》
- 福建省泉州市晉江市2023-2024學年八年級上學期期末考試數(shù)學試卷(含解析)
評論
0/150
提交評論