그래프 구현 방법
1. 그래프 클래스 정의
-
그래프는 노드와 간선을 사용하여 네트워크 구조를 모델링하는 자료구조입니다.
-
Graph
클래스는 노드와 그 인접 노드를 저장하기 위한 딕셔너리를 포함합니다.
그래프 클래스 정의 예시
class Graph: def __init__(self): self.graph = {} # 노드와 그 인접 노드를 저장할 딕셔너리
2. 간선 추가 메소드
-
add_edge
메소드는 두 노드 사이에 양방향 간선을 추가합니다. -
각 노드가 그래프에 없는 경우, 노드를 추가하고 빈 리스트를 할당합니다.
간선 추가 메소드 예시
def add_edge(self, node1, node2): if node1 not in self.graph: self.graph[node1] = [] if node2 not in self.graph: self.graph[node2] = [] self.graph[node1].append(node2) self.graph[node2].append(node1)
3. 그래프 출력 메소드
-
display
메소드는 그래프의 내용을 출력합니다. -
각 노드와 그에 인접한 노드들을 출력하여 그래프의 구조를 보여줍니다.
그래프 출력 메소드 예시
def display(self): for node in self.graph: print(f"{node} -> {self.graph[node]}")
4. 그래프 객체 생성 및 사용
-
Graph
클래스의 인스턴스를 생성하고, 간선을 추가하여 그래프를 구성합니다. -
display
메소드를 호출하여 그래프의 구조를 확인합니다.
그래프 객체 생성 및 사용 예시
# 그래프 객체 생성 g = Graph() # 간선 추가 g.add_edge('A', 'B') g.add_edge('A', 'C') g.add_edge('B', 'C') g.add_edge('B', 'D') # 그래프 출력 g.display()
학습 자료
AI 튜터
배포
디자인
업로드
수업 노트
즐겨찾기
도움말
코드 에디터
코드 실행
코드 생성
실행 결과