Programmers / 가장 먼 노드 / python

2025. 3. 31. 21:09·코딩테스트/programmers (python)

 

문제: https://school.programmers.co.kr/learn/courses/30/lessons/49189

 


문제 설명

 

n명이 입국심사를 위해 줄을 서서 기다리고 있습니다. 각 입국심사대에 있는 심사관마다 심사하는데 걸리는 시간은 다릅니다.

처음에 모든 심사대는 비어있습니다. 한 심사대에서는 동시에 한 명만 심사를 할 수 있습니다. 가장 앞에 서 있는 사람은 비어 있는 심사대로 가서 심사를 받을 수 있습니다. 하지만 더 빨리 끝나는 심사대가 있으면 기다렸다가 그곳으로 가서 심사를 받을 수도 있습니다.

모든 사람이 심사를 받는데 걸리는 시간을 최소로 하고 싶습니다.

입국심사를 기다리는 사람 수 n, 각 심사관이 한 명을 심사하는데 걸리는 시간이 담긴 배열 times가 매개변수로 주어질 때, 모든 사람이 심사를 받는데 걸리는 시간의 최솟값을 return 하도록 solution 함수를 작성해주세요.n개의 노드가 있는 그래프가 있습니다. 각 노드는 1부터 n까지 번호가 적혀있습니다. 1번 노드에서 가장 멀리 떨어진 노드의 갯수를 구하려고 합니다. 가장 멀리 떨어진 노드란 최단경로로 이동했을 때 간선의 개수가 가장 많은 노드들을 의미합니다.

노드의 개수 n, 간선에 대한 정보가 담긴 2차원 배열 vertex가 매개변수로 주어질 때, 1번 노드로부터 가장 멀리 떨어진 노드가 몇 개인지를 return 하도록 solution 함수를 작성해주세요.

 

제한사항

 

  • 노드의 개수 n은 2 이상 20,000 이하입니다.
  • 간선은 양방향이며 총 1개 이상 50,000개 이하의 간선이 있습니다.
  • vertex 배열 각 행 [a, b]는 a번 노드와 b번 노드 사이에 간선이 있다는 의미입니다.

 

 


 

나의 풀이

from collections import deque
def solution(n, edge):
    graph = [[] for _ in range(n + 1)]
    visited = [0] * (n + 1)
    
    for (a, b) in edge:
        graph[a].append(b)
        graph[b].append(a)
        
    q = deque()
    q.append(1)
    visited[1] = 1
    
    while q:
        s = q.popleft()
        
        for i in graph[s]:
            if not visited[i]:
                visited[i] = visited[s] + 1
                q.append(i)
    result = max(visited)
    return visited.count(result)

 

BFS를 사용해 방문 유무를 확인하며 가장 먼 거리 (max(visited))를 찾고 먼 거리에 있는 노드의 개수(visited.count(result))를 반환합니다.

 

 

 

'코딩테스트 > programmers (python)' 카테고리의 다른 글

Programmers / 문자열 압축 / python  (0) 2025.05.10
Programmers / 입국심사 / python  (0) 2025.03.27
Programmers / 거리두기 확인하기 / python  (0) 2025.03.25
Programmers / [PCCP 기출문제] 3번 / 충돌위험 찾기 / python  (0) 2025.03.24
Programmers / [PCCP 기출문제] 2번 / 퍼즐 게임 챌린지 / python  (0) 2025.03.16
'코딩테스트/programmers (python)' 카테고리의 다른 글
  • Programmers / 문자열 압축 / python
  • Programmers / 입국심사 / python
  • Programmers / 거리두기 확인하기 / python
  • Programmers / [PCCP 기출문제] 3번 / 충돌위험 찾기 / python
seulll
seulll
개인 공부 / 정리 블로그입니다
  • seulll
    seulll
    seulll
  • 전체
    오늘
    어제
    • 분류 전체보기 (330) N
      • 코딩테스트 (226) N
        • programmers (python) (156)
        • 백준 (python) (68) N
      • 자료구조 | 알고리즘 (14)
      • 개발 | 프로젝트 (40)
        • Python (4)
        • Java | Spring (7)
        • Android (4)
        • Unity (3)
        • API (4)
      • CS (15)
        • Network (5)
        • SQL (2)
        • OS (4)
      • 데이터 분석 (14)
      • 기타 (12)
  • 블로그 메뉴

    • 홈
    • 태그
    • 글쓰기
    • 설정
  • 링크

    • GitHub
  • 인기 글

  • 태그

    백엔드 개발자
    티스토리챌린지
    Boxplot
    프렌즈4블록
    Python
    웹크롤링
    그리디 알고리즘
    바다코끼리
    2 x n 타일링
    대입 표현식
    kakao map api
    파이썬
    야근 지수
    백엔드
    카카오맵 api
    solving environment
    API
    Greedy
    오차행렬
    박스플롯
    asterisk
    confusion matrix
    코딩테스트
    오블완
    데이터분석
    카카오맵
    프로그래머스
    백엔드 개발자 역량
    모델 성능 평가
    train_test_split
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
seulll
Programmers / 가장 먼 노드 / python
상단으로

티스토리툴바