본문 바로가기
Algorithm 💫/Problem Solving

[백준 10451번 순열 사이클(DFS)/ C++]

by 돼지고기맛있다 2021. 1. 22.
반응형

 

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

 

어떻게 보면 혼란스러울 수 있는데!

사실 연결돼 있는 노드 집합의 개수를 찾는 방식과 똑같다 ㅎㅎ

 

2021/01/22 - [Studying 📖/알고리듬(thm) 공부 🌱] - [백준 11724번 연결 요소의 개수(BFS, DFS)/ C++]

 

[백준 11724번 연결 요소의 개수(BFS, DFS)/ C++]

www.acmicpc.net/problem/11724 11724번: 연결 요소의 개수 첫째 줄에 정점의 개수 N과 간선의 개수 M이 주어진다. (1 ≤ N ≤ 1,000, 0 ≤ M ≤ N×(N-1)/2) 둘째 줄부터 M개의 줄에 간선의 양 끝점 u와 v가 주어..

ssinee.tistory.com

위 글과 비슷한 방식!🐶👍🏻

 

#include <iostream>
#include <vector>

using namespace std;

vector<int> connection[1002];
vector<bool> vis(1002, false);
void dfs(int v)
{
    vis[v] = true;
    for (int i = 0; i < connection[v].size(); i++) {
        int to = connection[v][i];
        if (!vis[to]) {
            dfs(to);
        }
    }
}

int main()
{
    int t, n;
    cin >> t;

    while (t--) {
        cin >> n;
        for (int i = 1; i <= n; i++) {
            connection[i].clear();
            vis[i] = false;
            int v;
            cin >> v;
            connection[i].push_back(v);
        }
        int count = 0;
        for (int i = 1; i <= n; i++) {
            if (!vis[i]) {
                count++;
                dfs(i);
            }
        }
        cout << count << "\n";
        }

    return 0;
}
반응형

댓글