cuốn sách gpt4 ai đã làm

Triển khai thuật toán Kruskal

In lại Tác giả: Người biết Thời gian cập nhật: 2024-03-12 20:00:21 28 4
mua khóa gpt4 Nike

1. Sơ đồ được xây dựng

2 mã

gói graph.kruskal; nhập java.util.ArrayList; nhập java.util.Collections; nhập java.util.List; nhập lớp công khai Kruskal { static int N = 100; new int[N]; static int n; static Edge e[] = new Edge[N * N]; for (int i = 0; i < e.length; i++) { e[i] = new Edge(); } } // Khởi tạo số bộ sưu tập thành chính nó static void Init(int n) { for (int i = 1 ; i <= n; i++) fa[i] = i; } // hợp nhất tĩnh int Hợp nhất(int a, int b) { int p = fa[a]; = q) return 0; for (int i = 1; i <= n; i++) { // Kiểm tra tất cả các nút và thay đổi số đã đặt q thành p if (fa[i] == q) fa[i] = p ; Gán số bộ sưu tập của a cho số bộ sưu tập của b } return 1; } // Tìm cây bao trùm tối thiểu static int Kruskal(int n) { int ans = 0; ; i < m; i++) if (Hợp nhất(edgeList.get(i).u, edgeList.get(i).v) == 1) { ans += edgeList.get(i).w; (n == 1)//n-1 thuật toán hợp nhất kết thúc return ans; } return 0; } public static void main(String[] args) { Scanner scanner = new Scanner(System.in); scanner.nextInt(); m = scanner.nextInt(); init(n); for (int i = 1; i <= m; i++) { e[i].u = scanner.nextInt(); .v = scanner.nextInt(); e[i].w = scanner.nextInt(); System.out.println("Chi phí tối thiểu là: " + Kruskal(n)); } } class Edge triển khai Comparable { int u; @Override public int so sánhTo(Object o) { if (this. w > ((Edge) o).w) { return 1; } else if (this.w == ((Edge) o).w) { return 0; } else { return -1; } }

Ba bài kiểm tra

Màu xanh lá cây là đầu vào và màu trắng là đầu ra.

28 4 0
Bài viết khuyến nghị: Giới thiệu thuật toán Prim
Bài viết khuyến nghị: Truy vấn và giải pháp chậm của MySQL
Bài viết khuyến nghị: python gọi lệnh scp thực hành
Bài viết khuyến nghị: vấn đề đường rừng
Chứng chỉ ICP Bắc Kinh số 000000
Hợp tác quảng cáo: 1813099741@qq.com 6ren.com
Xem sitemap của VNExpress