Python을 사용하여 위상 정렬 알고리즘을 구현하는 방법은 무엇입니까?
Python을 사용하여 위상 정렬 알고리즘을 구현하는 방법은 무엇입니까?
토폴로지 정렬은 방향성 비순환 그래프(DAG)를 정렬하는 데 사용되는 그래프 이론의 정렬 알고리즘입니다. 토폴로지 정렬에서 그래프의 노드는 작업 또는 이벤트를 나타내고 방향성 간선은 작업 또는 이벤트 간의 종속성을 나타냅니다. 정렬된 결과에서 모든 종속성이 충족되고 각 노드는 모든 이전 노드 이후에 순위가 지정됩니다.
Python에서 위상 정렬 알고리즘을 구현하는 것은 깊이 우선 탐색(DFS) 아이디어를 사용하여 해결할 수 있습니다. 다음은 구체적인 코드 예입니다.
from collections import defaultdict class Graph: def __init__(self, num_vertices): self.graph = defaultdict(list) self.num_vertices = num_vertices def add_edge(self, u, v): self.graph[u].append(v) def topological_sort_util(self, v, visited, stack): visited[v] = True for i in self.graph[v]: if visited[i] == False: self.topological_sort_util(i, visited, stack) stack.append(v) def topological_sort(self): visited = [False] * self.num_vertices stack = [] for i in range(self.num_vertices): if visited[i] == False: self.topological_sort_util(i, visited, stack) sorted_list = [] while stack: sorted_list.append(stack.pop()) return sorted_list # 测试代码 g = Graph(6) g.add_edge(5, 2) g.add_edge(5, 0) g.add_edge(4, 0) g.add_edge(4, 1) g.add_edge(2, 3) g.add_edge(3, 1) sorted_list = g.topological_sort() print("拓扑排序结果:", sorted_list)
위 코드는 먼저 가장자리 추가 및 위상 정렬과 같은 메서드를 포함하는 Graph 클래스를 정의합니다. 위상 정렬 중에는 그래프의 노드를 탐색하기 위해 깊이 우선 검색이 사용됩니다. 스택을 사용하여 방문한 노드를 저장하면 최종적으로 토폴로지 순서 규칙에 따라 정렬된 노드 목록을 얻을 수 있습니다.
위 코드에는 위상 정렬 알고리즘의 정확성을 확인하기 위한 간단한 테스트 사례도 포함되어 있습니다. 이 테스트 사례에서는 크기 6의 그래프가 정의되고 일부 노드와 간선이 추가됩니다. 마지막으로 위상적으로 정렬된 노드 목록을 인쇄합니다.
Python을 사용하여 위상 정렬 알고리즘을 구현하면 그래프의 종속성을 쉽게 처리할 수 있어 작업 스케줄링과 같은 문제에 매우 유용합니다. 이 알고리즘을 이해하고 적용함으로써 실제 문제를 더 잘 해결할 수 있습니다. 이 기사가 도움이 되기를 바랍니다.
위 내용은 Python을 사용하여 위상 정렬 알고리즘을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

Python의 Pandas 라이브러리를 사용할 때는 구조가 다른 두 데이터 프레임 사이에서 전체 열을 복사하는 방법이 일반적인 문제입니다. 두 개의 dats가 있다고 가정 해

이 기사는 Numpy, Pandas, Matplotlib, Scikit-Learn, Tensorflow, Django, Flask 및 요청과 같은 인기있는 Python 라이브러리에 대해 설명하고 과학 컴퓨팅, 데이터 분석, 시각화, 기계 학습, 웹 개발 및 H에서의 사용에 대해 자세히 설명합니다.

Uvicorn은 HTTP 요청을 어떻게 지속적으로 듣습니까? Uvicorn은 ASGI를 기반으로 한 가벼운 웹 서버입니다. 핵심 기능 중 하나는 HTTP 요청을 듣고 진행하는 것입니다 ...

파이썬에서 문자열을 통해 객체를 동적으로 생성하고 메소드를 호출하는 방법은 무엇입니까? 특히 구성 또는 실행 해야하는 경우 일반적인 프로그래밍 요구 사항입니다.

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

정규 표현식은 프로그래밍의 패턴 일치 및 텍스트 조작을위한 강력한 도구이며 다양한 응용 프로그램에서 텍스트 처리의 효율성을 높입니다.
