亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中Prime算法的原理是什么與怎么實現

發布時間:2022-09-14 17:38:21 來源:億速云 閱讀:168 作者:iii 欄目:開發技術

本篇內容主要講解“Java中Prime算法的原理是什么與怎么實現”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java中Prime算法的原理是什么與怎么實現”吧!

Prim算法介紹

1.點睛

在生成樹的過程中,把已經在生成樹中的節點看作一個集合,把剩下的節點看作另外一個集合,從連接兩個集合的邊中選擇一條權值最小的邊即可。

2.算法介紹

Java中Prime算法的原理是什么與怎么實現

首先任選一個節點,例如節點1,把它放在集合 U 中,U={1},那么剩下的節點為 V-U={2,3,4,5,6,7},集合 V 是圖的所有節點集合。

Java中Prime算法的原理是什么與怎么實現

現在只需要看看連接兩個集合(U 和 V-U)的邊中,哪一條邊的權值最小,把權值最小的邊關聯的節點加入集合 U 中。從上圖可以看出,連接兩個集合的 3 條邊中,1-2 邊的權值最小,選中它,把節點 2 加入集合 U 中,U={1,2},V - U={3,4,5,6},如下圖所示。

Java中Prime算法的原理是什么與怎么實現

再從連接兩個集合(U 和 V-U)的邊中選擇一條權最小的邊。從上圖看出,在連接兩個集合的4條邊中,節點2到節點7的邊權值最小,選中這條邊,把節點7加入集合U={1,2,7}中,V-U={3,4,5,6}。

如此下去,直到 U=V 結束,選中的邊和所有的節點組成的圖就是最小生成樹。這就是 Prim 算法。

直觀地看圖,很容易找出集合 U 到 集合 U-V 的邊中哪條邊的權值是最小的,但在程序中窮舉這些邊,再找最小值,則時間復雜度太高。可以通過設置數組巧妙解決這個問題,closet[j] 表示集合 V-U 中的節點 j 到集合 U 中的最鄰近點,lowcost[j] 表示集合 V-U 中節點 j 到集合 U 中最鄰近點的邊值,即邊(j,closest[j]) 的權值。

例如在上圖中,節點 7 到集合 U 中的最鄰近點是2,cloeest[7]=2。節點 7 到最鄰近點2 的邊值為1,即邊(2,7)的權值,記為 lowcost[7]=1,如下圖所示。

Java中Prime算法的原理是什么與怎么實現

所以只需在集合 V - U 中找到 lowcost[] 只最小的節點即可。

3. 算法步驟

1.初始化

令集合 U={u0},u0 屬于 V,并初始化數組 closest[]、lowcost[]和s[]。

2.在集合 V-U 中找 lowcost 值最小的節點t,即 lowcost[t]=min{lowcost[j]},j 屬于 V-U,滿足該公式的節點 t 就是集合 V-U 中連接 U 的最鄰近點。

3.將節點 t 加入集合 U 中。

4.如果集合 V - U 為空,則算法結束,否則轉向步驟 5。

5.對集合 V-U 中的所有節點 j 都更新其 lowcost[] 和 closest[]。if(C[t][j]<lowcost[j]){lowcost[j]=C[t][j];closest[j]=t;},轉向步驟2。

按照上面步驟,最終可以得到一棵權值之和最小的生成樹。

4.圖解

圖 G=(V,E)是一個無向連通帶權圖,如下圖所示。

Java中Prime算法的原理是什么與怎么實現

1 初始化。假設 u0=1,令集合 U={1},集合 V-U={2,3,4,5,6,7},s[1]=true,初始化數組 closest[]:除了節點1,其余節點均為1,表示集合 V-U 中的節點到集合 U 的最鄰近點均為1.lowcost[]:節點1到集合 V-U 中節點的邊值。closest[] 和 lowcost[] 如下圖所示。

Java中Prime算法的原理是什么與怎么實現

初始化后的圖為:

Java中Prime算法的原理是什么與怎么實現

2 找 lowcost 最小的節點,對應的 t=2,選中的邊和節點如下圖。

Java中Prime算法的原理是什么與怎么實現

3 加入集合U中。將節點 t 加入集合 U 中,U={1,2},同時更新 V-U={3,4,5,6,7}

4 更新。對 t 在集合 V-U 中的每一個鄰接點 j,都可以借助 t 更新。節點 2 的鄰接點是節點 3 和節點7。

C[2][3]=20<lowcost[3]=無窮大,更新最鄰近距離 lowcost[3]=20,最鄰近點 closest[3]=2;

C[2][7]=1<lowcost[7]=36,更新最鄰近距離 lowcost[7]=1,最鄰近點 closest[7]=2;

更新后的 closest[] 和 lowcost[] 如下圖所示。

Java中Prime算法的原理是什么與怎么實現

更新后的集合如下圖所示:

Java中Prime算法的原理是什么與怎么實現

5 找 lowcost 最小的節點,對應的 t=7,選中的邊和節點如下圖。

Java中Prime算法的原理是什么與怎么實現

6  加入集合U中。將節點 t 加入集合 U 中,U={1,2,7},同時更新 V-U={3,4,5,6}

7 更新。對 t 在集合 V-U 中的每一個鄰接點 j,都可以借助 t 更新。節點 7 的鄰接點是節點 3、4、5、6。

  • C[7][3]=4<lowcost[3]=20,更新最鄰近距離 lowcost[3]=4,最鄰近點 closest[3]=7;

  • C[7][4]=4<lowcost[4]=無窮大,更新最鄰近距離 lowcost[3]=9,最鄰近點 closest[4]=7;

  • C[7][5]=4<lowcost[5]=無窮大,更新最鄰近距離 lowcost[3]=16,最鄰近點 closest[5]=7;

  • C[7][6]=4<lowcost[6]=28,更新最鄰近距離 lowcost[3]=25,最鄰近點 closest[6]=7;

更新后的 closest[] 和 lowcost[] 如下圖所示。

Java中Prime算法的原理是什么與怎么實現

更新后的集合如下圖所示:

Java中Prime算法的原理是什么與怎么實現

8 找 lowcost 最小的節點,對應的 t=3,選中的邊和節點如下圖。

Java中Prime算法的原理是什么與怎么實現

9 加入集合U中。將節點 t 加入集合 U 中,U={1,2,3,7},同時更新 V-U={4,5,6}

10 更新。對 t 在集合 V-U 中的每一個鄰接點 j,都可以借助 t 更新。節點 3 的鄰接點是節點 4。

C[3][4]=15>lowcost[4]=9,不更新

closest[] 和 lowcost[] 數組不改變。

更新后的集合如下圖所示:

Java中Prime算法的原理是什么與怎么實現

11 找 lowcost 最小的節點,對應的 t=4,選中的邊和節點如下圖。

Java中Prime算法的原理是什么與怎么實現

12 加入集合U中。將節點 t 加入集合 U 中,U={1,2,3,4,7},同時更新 V-U={5,6}

13 更新。對 t 在集合 V-U 中的每一個鄰接點 j,都可以借助 t 更新。節點 4 的鄰接點是節點 5。

C[4][5]=3<lowcost[5]=16,更新最鄰近距離 lowcost[5]=3,最鄰近點 closest[5]=4;

更新后的 closest[] 和 lowcost[] 如下圖所示。

Java中Prime算法的原理是什么與怎么實現

更新后的集合如下圖所示:

Java中Prime算法的原理是什么與怎么實現

14 找 lowcost 最小的節點,對應的 t=5,選中的邊和節點如下圖。

Java中Prime算法的原理是什么與怎么實現

15 加入集合U中。將節點 t 加入集合 U 中,U={1,2,3,4,5,7},同時更新 V-U={6}

16 更新。對 t 在集合 V-U 中的每一個鄰接點 j,都可以借助 t 更新。節點 5 的鄰接點是節點 6。

C[5][6]=17<lowcost[6]=25,更新最鄰近距離 lowcost[6]=17,最鄰近點 closest[6]=5;

更新后的集合如下圖所示:

Java中Prime算法的原理是什么與怎么實現

17 找 lowcost 最小的節點,對應的 t=6,選中的邊和節點如下圖。

Java中Prime算法的原理是什么與怎么實現

18 加入集合U中。將節點 t 加入集合 U 中,U={1,2,3,4,5,6,7},同時更新 V-U={}

19 更新。對 t 在集合 V-U 中的每一個鄰接點 j,都可以借助 t 更新。節點 6 在集合 V-U 中無鄰接點。不用更新 closest[] 和 lowcost[] 。

20 得到的最小生成樹如下。最小生成樹的權值之和為 57.

Java中Prime算法的原理是什么與怎么實現

Prime 算法實現

1.構建后的圖

Java中Prime算法的原理是什么與怎么實現

2.代碼

package graph.prim;
 
import java.util.Scanner;
 
public class Prim {
    static final int INF = 0x3f3f3f3f;
    static final int N = 100;
    // 如果s[i]=true,說明頂點i已加入U
    static boolean s[] = new boolean[N];
    static int c[][] = new int[N][N];
    static int closest[] = new int[N];
    static int lowcost[] = new int[N];
 
    static void Prim(int n) {
        // 初始時,集合中 U 只有一個元素,即頂點 1
        s[1] = true;
        for (int i = 1; i <= n; i++) {
            if (i != 1) {
                lowcost[i] = c[1][i];
                closest[i] = 1;
                s[i] = false;
            } else
                lowcost[i] = 0;
        }
        for (int i = 1; i < n; i++) {
            int temp = INF;
            int t = 1;
            // 在集合中 V-u 中尋找距離集合U最近的頂點t
            for (int j = 1; j <= n; j++) {
                if (!s[j] && lowcost[j] < temp) {
                    t = j;
                    temp = lowcost[j];
                }
            }
            if (t == 1)
                break; // 找不到 t,跳出循環
            s[t] = true; // 否則,t 加入集合U
            for (int j = 1; j <= n; j++) { // 更新 lowcost 和 closest
                if (!s[j] && c[t][j] < lowcost[j]) {
                    lowcost[j] = c[t][j];
                    closest[j] = t;
                }
            }
        }
    }
 
    public static void main(String[] args) {
        int n, m, u, v, w;
        Scanner scanner = new Scanner(System.in);
        n = scanner.nextInt();
        m = scanner.nextInt();
        int sumcost = 0;
        for (int i = 1; i <= n; i++)
            for (int j = 1; j <= n; j++)
                c[i][j] = INF;
        for (int i = 1; i <= m; i++) {
            u = scanner.nextInt();
            v = scanner.nextInt();
            w = scanner.nextInt();
            c[u][v] = c[v][u] = w;
        }
        Prim(n);
        System.out.println("數組lowcost:");
 
        for (int i = 1; i <= n; i++)
            System.out.print(lowcost[i] + " ");
 
        System.out.println();
        for (int i = 1; i <= n; i++)
            sumcost += lowcost[i];
        System.out.println("最小的花費:" + sumcost);
    }
}

3.測試

Java中Prime算法的原理是什么與怎么實現

到此,相信大家對“Java中Prime算法的原理是什么與怎么實現”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

昌邑市| 上饶市| 蒙阴县| 华坪县| 嘉荫县| 灵川县| 湖口县| 密山市| 湖北省| 阳东县| 深水埗区| 青铜峡市| 永仁县| 滁州市| 宾阳县| 图片| 宁武县| 合山市| 花莲县| 逊克县| 玛纳斯县| 寿宁县| 保德县| 家居| 徐汇区| 定远县| 福清市| 泰宁县| 西盟| 洪江市| 新巴尔虎左旗| 安溪县| 怀仁县| 电白县| 兴城市| 临洮县| 新沂市| 康定县| 大兴区| 沂源县| 安泽县|