[백준] 10451번, 순열 사이클 (Python)

2021. 8. 8. 13:19·알고리즘/백준
728x90
반응형

문제

https://www.acmicpc.net/problem/10451

 

10451번: 순열 사이클

1부터 N까지 정수 N개로 이루어진 순열을 나타내는 방법은 여러 가지가 있다. 예를 들어, 8개의 수로 이루어진 순열 (3, 2, 7, 8, 1, 4, 5, 6)을 배열을 이용해 표현하면 \(\begin{pmatrix} 1 & 2 &3&4&5&6&7&8 \\  3

www.acmicpc.net

 

코드

import collections

t = int(input())
queue = collections.deque()

def bfs(index):
    queue.append(index)
    while queue:
        cur = queue.popleft()
        visited[cur] = True
        if visited[graph[cur]] == False:
            visited[graph[cur]] = True
            queue.append(graph[cur])

for i in range(t):
    n = int(input())
    graph = [0]+list(map(int, input().split()))
    visited = [0 for _ in range(n+1)]
    count = 0
    for j in range(1, n+1):
        if visited[j] == False:
            bfs(j)
            count += 1
    print(count)

visited로 방문체크를 해줘서 모든 정점노드들을 for문으로 돌아 방문하지 않은 정점일 경우 bfs를 실행한다.

 

즉, bfs 실행 횟수가 사이클이 생긴 횟수와 같아진다.

반응형
저작자표시 (새창열림)

'알고리즘 > 백준' 카테고리의 다른 글

[백준] 3190번, 뱀 (Python)  (0) 2021.08.12
[백준] 3055번, 탈출 (Python)  (0) 2021.08.12
[백준] 1389번, 케빈 베이컨의 6단계 법칙 (Python)  (0) 2021.08.07
[백준] 2193번, 이친수 (Python)  (0) 2021.08.03
[백준] 1912번, 연속합 (Python)  (0) 2021.07.30
'알고리즘/백준' 카테고리의 다른 글
  • [백준] 3190번, 뱀 (Python)
  • [백준] 3055번, 탈출 (Python)
  • [백준] 1389번, 케빈 베이컨의 6단계 법칙 (Python)
  • [백준] 2193번, 이친수 (Python)
wookcode
wookcode
공부한 내용들을 정리하고 기록하는 블로그입니다.
    반응형
  • wookcode
    wookcode
    wookcode
  • 전체
    오늘
    어제
    • 카테고리 (196)
      • study (1)
        • 아파치 카프카 애플리케이션 프로그래밍 with 자.. (0)
        • 인프런 (1)
      • Live Study (15)
      • Programming (14)
        • Java (8)
        • Python (1)
        • Springboot (5)
        • MSA (0)
      • 알고리즘 (117)
        • 백준 (58)
        • 프로그래머스 (59)
      • 에러로그 (5)
      • 항해99 (23)
      • 면접 (1)
      • 프로젝트 (1)
      • CS (19)
        • 네트워크 (2)
        • 운영체제 (2)
        • 데이터베이스 (2)
        • 컴퓨터구조 (1)
        • Java (8)
        • Spring (4)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    정리
    후기
    미니프로젝트
    그리디
    회고
    카카오코딩테스트
    SpringBoot
    김영한
    인프런
    카카오인턴
    브루트포스
    파이썬
    백준
    버그
    알고리즘
    SFlash
    해결
    에러
    조합
    항해99
    괄호
    spring
    스파르타코딩클럽
    orm
    jpa
    프로그래머스
    코딩테스트
    java
    실전프로젝트
    항해마켓
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
wookcode
[백준] 10451번, 순열 사이클 (Python)
상단으로

티스토리툴바