알고리즘/BOJ

[백준] 3088 화분 부수기

세진짱 2020. 3. 30. 23:31

 

오래 고민한 문제다..!

이런거 참 생각을 잘 못하는거같다

 

어떤 화분을 깨면 화분에 해당하는 숫자가 오른쪽에 임의에 화분에 있다면 그 화분도 깰수있다

계속 연속적으로 이어져간다

 

자 생각을 해보자..!

 

맨 처음 화분은 무조건 깨야만한다. 안그러면 아무도 깨주지 않으므로..!

그럼 맨 처음 화분에 포함되는 수를 앞으로 만난다면 그 화분도 무조건 깨져야한다

그럼 입력받으면서 처리할 수 있다..!

 

화분을 깨지는 수를 계속 저장해가며 하나라도 가지고 있으면 깨버리자!

소스는 참 짧다!

 

처음에는 set을 썼는데 그럼 시간이 너무 오래 걸린다

배열을 이용하자

 

소스코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <bits/stdc++.h>
using namespace std;
 
#define ll long long
int n,ans;
bool check[1000001];
int main(){
    scanf(" %d",&n);
    for(int i=0;i<n;i++){
        int a,b,c; scanf(" %d %d %d",&a,&b,&c);
        if(!check[a] && !check[b] && !check[c]) ans++;
        check[a]=check[b]=check[c]=true;
    }
    printf("%d\n",ans);
}