10451번: 순열 사이클
문제 )
1부터 N까지 정수 N개로 이루어진 순열을 나타내는 방법은 여러 가지가 있다. 예를 들어, 8개의 수로 이루어진 순열 (3, 2, 7, 8, 1, 4, 5, 6)을 배열을 이용해 표현하면
![](https://blog.kakaocdn.net/dn/cjnO54/btruG0xYitA/4jBzMK8nWIwSXHrGgoYG1k/img.png)
와 같다. 또는, Figure 1과 같이 방향 그래프로 나타낼 수도 있다.
순열을 배열을 이용해
![](https://blog.kakaocdn.net/dn/XfeRl/btruLsNGeUI/Fo5A33Syi7SayLZgumUSi0/img.png)
로 나타냈다면, i에서 πi로 간선을 이어 그래프로 만들 수 있다.
Figure 1에 나와있는 것 처럼, 순열 그래프 (3, 2, 7, 8, 1, 4, 5, 6) 에는 총 3개의 사이클이 있다. 이러한 사이클을 "순열 사이클" 이라고 한다.
N개의 정수로 이루어진 순열이 주어졌을 때, 순열 사이클의 개수를 구하는 프로그램을 작성하시오.
![](https://blog.kakaocdn.net/dn/QeJ96/btruQkODqFj/9XisfbzlhnqxIrakgszuGk/img.png)
입력 :
첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스의 첫째 줄에는 순열의 크기 N (2 ≤ N ≤ 1,000)이 주어진다. 둘째 줄에는 순열이 주어지며, 각 정수는 공백으로 구분되어 있다.
출력 :
각 테스트 케이스마다, 입력으로 주어진 순열에 존재하는 순열 사이클의 개수를 출력한다.
풀이)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
import sys
sys.setrecursionlimit(10**7)
def dfs(n):
visited[n] = 1
next = li[n]
if visited[next] == 0:
dfs(next)
T = int(input())
for _ in range(T):
n = int(input())
li = [0] + list(map(int, input().split()))
visited = [False for i in range(n + 1)]
cnt = 0
for i in range(1, n + 1):
if visited[i] == 0:
dfs(i)
cnt += 1
print(cnt)
|
cs |
출처 : 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
'Develop > 백준 (python)' 카테고리의 다른 글
[백준] 11724번: 연결 요소의 개수 (python) (0) | 2022.03.02 |
---|---|
[백준] 2667번: 단지번호붙이기 (python) (0) | 2022.03.02 |
[백준] 2331번: 반복수열 (python) (0) | 2022.03.01 |
[백준] 1697번: 숨바꼭질 (python) (0) | 2022.02.27 |
[백준] 2178번: 미로 탐색 (python) (0) | 2022.02.27 |