博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
pta 编程题21 公路村村通
阅读量:5309 次
发布时间:2019-06-14

本文共 2168 字,大约阅读时间需要 7 分钟。

其它pta数据结构编程题请参见:

这道题考察最小生成树问题,用的是Prim算法。

和Dijkstra算法相比,没有了collect数组,因为dist[v] == 0就代表v被已收录。

1 #include 
2 using namespace std; 3 4 int N, M; 5 int** G; 6 void buildGraph(); 7 void deleteGraph(); 8 int prim(); 9 int findMinDist(int dist[]); 10 11 int main() 12 { 13 cin >> N >> M; 14 buildGraph(); 15 cout << prim(); 16 deleteGraph(); 17 return 0; 18 } 19 20 void buildGraph() 21 { 22 int i, j; 23 G = new int*[N]; 24 for (i = 0; i < N; i++) 25 { 26 G[i] = new int[N]; 27 for (j = 0; j < N; j++) 28 G[i][j] = INT_MAX; 29 } 30 31 int v, w, d; 32 for (i = 0; i < M; i++) 33 { 34 cin >> v >> w >> d; 35 v--; w--;//输入从1计数 36 G[v][w] = d; 37 G[w][v] = d; 38 } 39 } 40 41 void deleteGraph() 42 { 43 for (int i = 0; i < N; i++) 44 delete[] G[i]; 45 delete[] G; 46 } 47 48 int findMinDist(int dist[]) 49 { /*返回未收录进MST的顶点中dist最小的顶点*/ 50 int minV, v; 51 int minDist = INT_MAX; 52 for (v = 0; v < N; v++) 53 { 54 if (dist[v] != 0 && dist[v] < minDist) 55 { 56 minDist = dist[v]; 57 minV = v; 58 } 59 } 60 if (minDist < INT_MAX) 61 return minV; 62 return -1; 63 } 64 65 int prim() 66 { /*返回最小生成树的权重*/ 67 int v, w, vCount = 0; 68 int totalWeight = 0; 69 int* dist = new int[N]; 70 71 /*初始化,初始点下标为0*/ 72 for (v = 0; v < N; v++) 73 dist[v] = G[0][v]; 74 75 /*将0收进最小生成树MST*/ 76 dist[0] = 0; 77 vCount++; 78 79 while (true) 80 { 81 v = findMinDist(dist); 82 if (v == -1) 83 break; 84 85 totalWeight += dist[v]; 86 dist[v] = 0; //收录v 87 vCount++; 88 89 for (w = 0; w < N; w++) 90 { 91 /*如果w没有被收录*/ 92 if (dist[w] != 0 && G[v][w] < dist[w]) 93 { 94 dist[w] = G[v][w]; 95 } 96 } 97 } 98 99 delete[] dist;100 101 if (vCount < N)102 return -1;103 return totalWeight;104 }

 

转载于:https://www.cnblogs.com/lxc1910/p/8992303.html

你可能感兴趣的文章
把word文档中的所有图片导出
查看>>
浏览器的判断;
查看>>
ubuntu 18.04取消自动锁屏以及设置键盘快捷锁屏
查看>>
Leetcode 589. N-ary Tree Preorder Traversal
查看>>
机器学习/深度学习/其他开发环境搭建记录
查看>>
xml.exist() 实例演示
查看>>
判断是否为空然后赋值
查看>>
zabbix监控日志文件
查看>>
正则表达式
查看>>
pip install torch on windows, and the 'from torch._C import * ImportError: DLL load failed:' s...
查看>>
环套树
查看>>
java基础(一):我对java的三个环境变量的简单理解和配置
查看>>
arcgis api 4.x for js 结合 Echarts4 实现散点图效果(附源码下载)
查看>>
YTU 2625: B 构造函数和析构函数
查看>>
apache自带压力测试工具ab的使用及解析
查看>>
C#使用Xamarin开发可移植移动应用(2.Xamarin.Forms布局,本篇很长,注意)附源码
查看>>
jenkins搭建
查看>>
C#中使用Split分隔字符串的技巧
查看>>
eclipse的调试方法的简单介绍
查看>>
加固linux
查看>>