Java java지도 시간 Java를 사용하여 최소 신장 트리 알고리즘을 구현하는 방법

Java를 사용하여 최소 신장 트리 알고리즘을 구현하는 방법

Sep 21, 2023 pm 12:36 PM
자바 구현 최소 스패닝 트리 알고리즘

Java를 사용하여 최소 신장 트리 알고리즘을 구현하는 방법

Java를 사용하여 최소 신장 트리 알고리즘을 구현하는 방법

최소 신장 트리 알고리즘은 그래프 이론의 고전적인 문제로, 가중치 연결 그래프의 최소 신장 트리를 해결하는 데 사용됩니다. 이 기사에서는 Java 언어를 사용하여 이 알고리즘을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

  1. 문제 설명
    각 간선에 가중치가 있는 연결된 그래프 G가 주어지면 T의 모든 간선 가중치의 합이 최소가 되는 최소 스패닝 트리 T를 찾아야 합니다.
  2. Prim의 알고리즘
    Prim의 알고리즘은 최소 신장 트리 문제를 해결하는 데 사용되는 그리디 알고리즘입니다. 기본 아이디어는 정점에서 시작하여 스패닝 트리를 점진적으로 확장하여 모든 정점이 스패닝 트리에 추가될 때까지 매번 기존 스패닝 트리에 가장 가까운 정점을 선택하는 것입니다.

다음은 Prim 알고리즘의 Java 구현 예입니다.

import java.util.ArrayList;
import java.util.List;
import java.util.PriorityQueue;
import java.util.Queue;

class Edge implements Comparable<Edge> {
    int from;
    int to;
    int weight;
    
    public Edge(int from, int to, int weight) {
        this.from = from;
        this.to = to;
        this.weight = weight;
    }
    
    @Override
    public int compareTo(Edge other) {
        return Integer.compare(this.weight, other.weight);
    }
}

public class Prim {
    public static List<Edge> calculateMST(List<List<Edge>> graph) {
        int n = graph.size();
        boolean[] visited = new boolean[n];
        Queue<Edge> pq = new PriorityQueue<>();
        
        // Start from vertex 0
        int start = 0;
        visited[start] = true;
        for (Edge e : graph.get(start)) {
            pq.offer(e);
        }
        
        List<Edge> mst = new ArrayList<>();
        while (!pq.isEmpty()) {
            Edge e = pq.poll();
            int from = e.from;
            int to = e.to;
            int weight = e.weight;
            
            if (visited[to]) {
                continue;
            }
            
            visited[to] = true;
            mst.add(e);
            
            for (Edge next : graph.get(to)) {
                if (!visited[next.to]) {
                    pq.offer(next);
                }
            }
        }
        
        return mst;
    }
}
로그인 후 복사
  1. Kruskal 알고리즘
    Kruskal 알고리즘도 최소 스패닝 트리 문제를 해결하는 데 사용되는 그리디 알고리즘입니다. 기본 아이디어는 가중치에 따라 그래프의 모든 가장자리를 작은 것부터 큰 것까지 정렬한 다음 가장자리를 추가할 때 가장자리의 두 끝점이 동일하지 않은 경우 차례로 스패닝 트리에 추가하는 것입니다. 연결된 구성 요소인 경우 이러한 가장자리를 스패닝 트리에 추가할 수 있습니다. 두 끝점은 연결된 구성 요소로 병합됩니다.

다음은 Kruskal 알고리즘의 Java 구현 예입니다.

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

class Edge implements Comparable<Edge> {
    int from;
    int to;
    int weight;
    
    public Edge(int from, int to, int weight) {
        this.from = from;
        this.to = to;
        this.weight = weight;
    }
    
    @Override
    public int compareTo(Edge other) {
        return Integer.compare(this.weight, other.weight);
    }
}

public class Kruskal {
    public static List<Edge> calculateMST(List<Edge> edges, int n) {
        List<Edge> mst = new ArrayList<>();
        Collections.sort(edges);
        
        int[] parent = new int[n];
        for (int i = 0; i < n; i++) {
            parent[i] = i;
        }
        
        for (Edge e : edges) {
            int from = e.from;
            int to = e.to;
            int weight = e.weight;
            
            int parentFrom = findParent(from, parent);
            int parentTo = findParent(to, parent);
            
            if (parentFrom != parentTo) {
                mst.add(e);
                parent[parentFrom] = parentTo;
            }
        }
        
        return mst;
    }
    
    private static int findParent(int x, int[] parent) {
        if (x != parent[x]) {
            parent[x] = findParent(parent[x], parent);
        }
        
        return parent[x];
    }
}
로그인 후 복사
  1. 사용 예
    다음은 간단한 사용 예입니다.
import java.util.ArrayList;
import java.util.List;

public class Main {
    public static void main(String[] args) {
        List<List<Edge>> graph = new ArrayList<>();
        graph.add(new ArrayList<>());
        graph.add(new ArrayList<>());
        graph.add(new ArrayList<>());
        graph.add(new ArrayList<>());
        
        graph.get(0).add(new Edge(0, 1, 2));
        graph.get(0).add(new Edge(0, 2, 3));
        graph.get(1).add(new Edge(1, 0, 2));
        graph.get(1).add(new Edge(1, 2, 1));
        graph.get(1).add(new Edge(1, 3, 5));
        graph.get(2).add(new Edge(2, 0, 3));
        graph.get(2).add(new Edge(2, 1, 1));
        graph.get(2).add(new Edge(2, 3, 4));
        graph.get(3).add(new Edge(3, 1, 5));
        graph.get(3).add(new Edge(3, 2, 4));
        
        List<Edge> mst = Prim.calculateMST(graph);
        System.out.println("Prim算法得到的最小生成树:");
        for (Edge e : mst) {
            System.out.println(e.from + " -> " + e.to + ",权重:" + e.weight);
        }
        
        List<Edge> edges = new ArrayList<>();
        edges.add(new Edge(0, 1, 2));
        edges.add(new Edge(0, 2, 3));
        edges.add(new Edge(1, 2, 1));
        edges.add(new Edge(1, 3, 5));
        edges.add(new Edge(2, 3, 4));
        
        mst = Kruskal.calculateMST(edges, 4);
        System.out.println("Kruskal算法得到的最小生成树:");
        for (Edge e : mst) {
            System.out.println(e.from + " -> " + e.to + ",权重:" + e.weight);
        }
    }
}
로그인 후 복사

위의 예제 프로그램을 실행하면 다음과 같은 출력을 얻을 수 있습니다.

Prim算法得到的最小生成树:
0 -> 1,权重:2
1 -> 2,权重:1
2 -> 3,权重:4
Kruskal算法得到的最小生成树:
1 -> 2,权重:1
0 -> 1,权重:2
2 -> 3,权重:4
로그인 후 복사

위는 Java에서 최소 스패닝 트리 알고리즘을 구현하기 위한 구체적인 코드 예제입니다. 이러한 샘플 코드를 통해 독자는 최소 신장 트리 알고리즘의 구현 과정과 원리를 더 잘 이해하고 배울 수 있습니다. 이 글이 독자들에게 도움이 되기를 바랍니다.

위 내용은 Java를 사용하여 최소 신장 트리 알고리즘을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Java를 사용하여 동적 프로그래밍 알고리즘을 구현하는 방법 Java를 사용하여 동적 프로그래밍 알고리즘을 구현하는 방법 Sep 19, 2023 am 11:16 AM

Java를 사용하여 동적 프로그래밍 알고리즘을 구현하는 방법 동적 프로그래밍은 다단계 의사결정 문제를 해결하기 위한 최적화 방법입니다. 각 단계는 알려진 정보를 기반으로 결정을 내리고 각 결정의 결과를 기록합니다. 후속 단계에서 사용되는 것입니다. 실제 응용에서 동적 프로그래밍은 일반적으로 최단 경로, 최대 부분 수열 합, 배낭 문제 등과 같은 최적화 문제를 해결하는 데 사용됩니다. 이 기사에서는 Java 언어를 사용하여 동적 프로그래밍 알고리즘을 구현하는 방법을 소개하고 특정 코드 예제를 제공합니다. 1. 동적 프로그래밍 알고리즘의 기본 원리

C#을 사용하여 최소 스패닝 트리 알고리즘을 작성하는 방법 C#을 사용하여 최소 스패닝 트리 알고리즘을 작성하는 방법 Sep 19, 2023 pm 01:55 PM

C#을 사용하여 최소 스패닝 트리 알고리즘을 작성하는 방법 최소 스패닝 트리 알고리즘은 그래프의 연결 문제를 해결하는 데 사용되는 중요한 그래프 이론 알고리즘입니다. 컴퓨터 과학에서 최소 스패닝 트리(Minimum Spanning Tree)는 스패닝 트리의 모든 간선의 가중치의 합이 가장 작은 연결된 그래프의 스패닝 트리를 의미합니다. 이 문서에서는 C#을 사용하여 최소 스패닝 트리 알고리즘을 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저, 문제를 표현하기 위해 그래프 데이터 구조를 정의해야 합니다. C#에서는 인접 행렬을 사용하여 그래프를 나타낼 수 있습니다. 인접 행렬은 각 요소가 나타내는 2차원 배열입니다.

PHP를 사용하여 간단한 SEO 최적화 기능을 개발하는 방법 PHP를 사용하여 간단한 SEO 최적화 기능을 개발하는 방법 Sep 20, 2023 pm 04:18 PM

PHP를 사용하여 간단한 SEO 최적화 기능을 개발하는 방법 SEO(SearchEngineOptimization) 또는 검색 엔진 최적화는 웹 사이트의 구조와 콘텐츠를 개선하여 더 많은 유기적인 트래픽을 확보함으로써 검색 엔진에서 웹 사이트의 순위를 높이는 것을 의미합니다. 웹사이트 개발에서 PHP를 사용하여 간단한 SEO 최적화 기능을 구현하는 방법은 무엇입니까? 이 기사에서는 개발자가 PHP 프로젝트에서 SEO 최적화를 구현하는 데 도움이 되는 몇 가지 일반적으로 사용되는 SEO 최적화 기술과 특정 코드 예제를 소개합니다. 1. 사용하기 편리하다

Java를 사용하여 RSA 암호화 알고리즘을 구현하는 방법 Java를 사용하여 RSA 암호화 알고리즘을 구현하는 방법 Sep 20, 2023 pm 02:33 PM

Java를 사용하여 RSA 암호화 알고리즘을 구현하는 방법 RSA(Rivest-Shamir-Adleman)는 비대칭 암호화 알고리즘으로 현재 가장 일반적으로 사용되는 암호화 알고리즘 중 하나입니다. 이 기사에서는 Java 언어를 사용하여 RSA 암호화 알고리즘을 구현하는 방법을 소개하고 특정 코드 예제를 제공합니다. 키 쌍 생성 먼저 공개 키와 개인 키로 구성된 RSA 키 쌍을 생성해야 합니다. 공개 키는 데이터를 암호화하는 데 사용될 수 있고, 개인 키는 데이터를 해독하는 데 사용될 수 있습니다. 다음은 RSA 키 쌍을 생성하는 코드 예제입니다.

Java를 사용하여 Kruskal 알고리즘을 구현하는 방법 Java를 사용하여 Kruskal 알고리즘을 구현하는 방법 Sep 19, 2023 am 11:39 AM

Java를 사용하여 Kruskal의 알고리즘을 구현하는 방법 Kruskal의 알고리즘은 최소 신장 트리 문제를 해결하는 데 일반적으로 사용되는 알고리즘으로 Edge를 진입점으로 사용하여 점차적으로 최소 신장 트리를 구축합니다. 이 기사에서는 Java를 사용하여 Kruskal의 알고리즘을 구현하는 방법을 자세히 설명하고 구체적인 코드 예제를 제공합니다. 알고리즘 원리 크루스칼 알고리즘의 기본 원리는 모든 edge를 가중치가 작은 것부터 큰 것 순으로 정렬한 후 작은 것부터 큰 것 순으로 edge를 선택하는 것이지만 순환을 형성할 수는 없다. 구체적인 구현 단계는 다음과 같습니다.

Java를 활용하여 온라인 시험 시스템의 시험 배치 조정 기능 구현 Java를 활용하여 온라인 시험 시스템의 시험 배치 조정 기능 구현 Sep 25, 2023 am 08:45 AM

온라인 시험 시스템의 시험 준비 조정 기능에 대한 Java 구현 소개: 인터넷 기술의 발전으로 점점 더 많은 학교와 훈련 기관이 시험 및 평가를 위해 온라인 시험 시스템을 사용하도록 선택하고 있습니다. 시험 일정 조정은 온라인 시험 시스템의 중요한 기능으로 관리자가 실제 상황에 따라 시험 시간 및 시험 관련 정보를 유연하게 조정할 수 있도록 도와줍니다. 이 글에서는 Java 프로그래밍을 사용하여 온라인 시험 시스템의 시험 일정 조정 기능을 구현하는 방법을 자세히 소개하고 구체적인 코드 예제를 제공합니다. 데이터베이스 설계 시험 준비 조정 기능 필요

쉬운 솔루션: pip 미러 소스 사용 기술에 대한 완벽한 가이드 쉬운 솔루션: pip 미러 소스 사용 기술에 대한 완벽한 가이드 Jan 16, 2024 am 10:31 AM

원클릭 솔루션: pip 미러 소스의 사용 기술을 빠르게 익히십시오. 소개: pip는 Python 패키지를 쉽게 설치, 업그레이드 및 관리할 수 있는 가장 일반적으로 사용되는 Python용 패키지 관리 도구입니다. 그러나 잘 알려진 이유로 인해 기본 미러 소스를 사용하여 설치 패키지를 다운로드하는 것이 더 느립니다. 이 문제를 해결하려면 국내 미러 소스를 사용해야 합니다. 이 기사에서는 pip 미러 소스의 사용 기술을 빠르게 익히는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 시작하기 전에 pip 미러 소스의 개념을 이해하세요.

Java로 구현된 추천 알고리즘 및 구현 Java로 구현된 추천 알고리즘 및 구현 Jun 18, 2023 pm 02:51 PM

인터넷의 발달로 인해 네트워크상의 데이터 양이 폭발적으로 증가하여, 많은 양의 정보에 직면했을 때 사용자가 정말로 필요한 콘텐츠를 빠르고 정확하게 찾는 것이 어려워졌습니다. 시대의 요구에 따라 등장한 추천 알고리즘은 사용자 행동 데이터를 기록하고 분석하여 사용자에게 개인화된 서비스와 추천 콘텐츠를 제공함으로써 사용자 만족도와 충성도를 향상시킵니다. 대규모 소프트웨어 개발을 위해 선택되는 언어로서 Java는 추천 알고리즘 구현에도 널리 사용됩니다. 1. 추천 알고리즘 추천 알고리즘은 사용자 상호작용, 행동, 관심 데이터를 분석하고 마이닝하는 방법입니다.

See all articles