연결된 정점 쌍을 기반으로 그래프 작성
"n개의 행에 양의 정수 쌍이 포함되어 있고, 각 쌍은 그래프의 두 정점 사이의 연결을 식별합니다."라는 개별 그래프가 몇 개 생성되는지 확인해야 합니다. [4 3], [1 4], [5 6]의 3개 쌍이 있다고 가정합니다. 대답은 2입니다. [4 3]&[1 4]는 하나의 그래프([1 3 4])로 병합되고 두 번째 그래프는 [5 6]이기 때문입니다. 다른 쌍: [4 3], [1 4], [5 6], [4 6]을 추가하면 답은 1이 됩니다(1개의 그래프만 연결됨: [1 3 4 5 6]). p>
Java를 사용하여 이 문제를 해결했지만 10000쌍이 넘는 경우 효율적이지 않았고 매우 느렸습니다. 코드는 대략 다음과 같습니다.
으아아아성능을 향상시키는 방법은 무엇입니까? 기성 솔루션을 요구하는 것은 아니지만 작업 속도를 크게 향상시킬 수 있는 내가 알지 못하는 알고리즘이 있을 수 있습니까?
정답
연결된 구성 요소의 수를 얻으려면 분리 집합을 사용할 수 있습니다. 이는 입력이 가장자리의 list
라고 가정하는 간단한 구현입니다.
노드 수(n
)已知,并且我们可以假设所有节点标签都是 1
和 n
之间的整数,我们可以通过使用数组而不是 map
)가 최적화되고 에지가 추가됨에 따라 연결된 구성 요소 수를 추적하는 경우
위 내용은 연결된 정점 쌍을 기반으로 그래프 작성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제









