Advertisement
Pug_coder

PRIM_THief

May 7th, 2021
118
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Go 1.30 KB | None | 0 0
  1. package main
  2.  
  3. import (
  4.     "fmt"
  5. )
  6.  
  7. const INF = 1000000000
  8.  
  9. var (
  10.     vertexCounter, edgeCounter, result, v, first, second, length int
  11.     graph [][]int
  12.     used []bool
  13.     min_e []int
  14.     sel_e []int
  15. )
  16.  
  17. func Prim() {
  18.     min_e[0] = 0
  19.     for i := 0; i < vertexCounter; i++ {
  20.         v = -1
  21.         for j := 0; j < vertexCounter; j++ {
  22.             if !used[j] && (v == -1 || min_e[j] < min_e[v]) {
  23.                 v = j
  24.             }
  25.         }
  26.         if min_e[v] == INF {
  27.             fmt.Println("No MST!")
  28.             break
  29.         }
  30.         used[v] = true
  31.         if sel_e[v] != -1 {
  32.             result += min_e[v]
  33.         }
  34.         for to := 0; to < vertexCounter; to++ {
  35.             if graph[v][to] < min_e[to] {
  36.                 min_e[to] = graph[v][to]
  37.                 sel_e[to] = v
  38.             }
  39.         }
  40.     }
  41. }
  42.  
  43. func ReadAndCreateGraph() {
  44.     fmt.Scanf("%d\n%d", &vertexCounter, &edgeCounter)
  45.     graph = make([][]int, vertexCounter)
  46.     used = make([]bool, vertexCounter)
  47.     min_e = make([]int, vertexCounter)
  48.     sel_e = make([]int, vertexCounter)
  49.  
  50.     for i := 0; i < vertexCounter; i++ {
  51.         min_e[i] = INF
  52.         sel_e[i] = -1
  53.         graph[i] = make([]int, vertexCounter)
  54.         for j := 0; j < vertexCounter; j++ {
  55.             graph[i][j] = INF
  56.         }
  57.     }
  58.  
  59.     for i := 0; i < edgeCounter; i++ {
  60.         fmt.Scanf("%d %d %d", &first, &second, &length)
  61.         graph[first][second] = length
  62.         graph[second][first] = length
  63.     }
  64. }
  65.  
  66. func main() {
  67.     ReadAndCreateGraph()
  68.     Prim()
  69.     fmt.Println(result)
  70. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement