App下載

經典Java面試題解析:最小生成樹

黃色相思情 2023-07-11 09:18:20 瀏覽數(shù) (1795)
反饋

在Java的面試中,最小生成樹是一個常見的算法主題。本文將介紹一道經典的Java面試題——最小生成樹,并提供詳細的解析和解題思路。

題目

給定一個帶權無向圖,找到一棵包含所有節(jié)點的最小生成樹。

解析與解題思路

最小生成樹是一個圖論中的重要概念,指的是在無向圖中找到一棵生成樹,使得所有邊的權值之和最小。

在解決最小生成樹問題時,我們可以使用貪心算法中的Prim算法或Kruskal算法。

  1. Prim算法:
    首先,我們隨機選擇一個節(jié)點作為起始節(jié)點,將其加入到最小生成樹中,并將其標記為已訪問。
    然后,我們從已訪問的節(jié)點集合中選取一個節(jié)點,該節(jié)點到未訪問的節(jié)點的邊權值最小,將這個邊和對應的未訪問節(jié)點加入到最小生成樹中。
    不斷重復上述步驟,直到所有節(jié)點都被訪問。
  2. Kruskal算法:
    首先,我們將所有邊按照權值從小到大進行排序。
    然后,從權值最小的邊開始遍歷,如果這條邊的兩個節(jié)點不在同一個連通分量中,就將這條邊加入到最小生成樹中,并將這兩個節(jié)點合并到同一個連通分量中。
    不斷重復上述步驟,直到最小生成樹中包含了所有節(jié)點。

通過Prim算法或Kruskal算法,我們可以找到一個包含所有節(jié)點的最小生成樹。

以下是Java代碼實例(使用Prim算法):

import java.util.Arrays;

public class MinimumSpanningTree {
    public static int primMST(int[][] graph) {
        int n = graph.length;
        int[] key = new int[n]; // 存儲節(jié)點到最小生成樹的最小權值
        boolean[] visited = new boolean[n]; // 記錄節(jié)點是否已訪問
        Arrays.fill(key, Integer.MAX_VALUE);

        key[0] = 0; // 選擇第一個節(jié)點作為起始節(jié)點
        int minCost = 0;

        for (int i = 0; i < n; i++) {
            int u = -1; // 用于存儲當前的最小權值節(jié)點

            for (int v = 0; v < n; v++) {
                if (!visited[v] && (u == -1 || key[v] < key[u])) {
                    u = v;
                }
            }

            visited[u] = true;
            minCost += key[u];

            for (int v = 0; v < n; v++) {
                if (!visited[v] && graph[u][v] != 0 && graph[u][v] < key[v]) {
                    key[v] = graph[u][v];
                }
            }
        }

        return minCost;
    }

    public static void main(String[] args) {
        int[][] graph = {
            {0, 2, 0, 6, 0},
            {2, 0, 3, 8, 5},
            {0, 3, 0, 0, 7},
            {6, 8, 0, 0, 9},
            {0, 5, 7, 9, 0}
        };

        int minCost = primMST(graph);
        System.out.println("最小生成樹的權值之和為:" + minCost);
    }
}

結論

通過Prim算法或Kruskal算法,我們可以找到一個包含所有節(jié)點的最小生成樹。最小生成樹是面試中常見的算法題目,掌握了解題思路和實現(xiàn)代碼,我們能夠在面試中更加自信地回答相關問題。

 學java,就到java編程獅!


0 人點贊