알고리즘/SW Expert Academy

[SWEA] 4112 이상한 피라미드 탐험

세진짱 2020. 1. 11. 22:04

 

오늘부터 SWEA 문제를 풀어보기로 했다!

처음으로 풀어본 문제다! 수학적인 문제라고 생각하는데 생각도못하고 오~~래 틀렸다

 

이 문제는 부분합으로 배열을 구하면 각 층을 index라 생각할 수 있고

층에있는 수의 갯수를 psum[index] 라고 생각 할 수 있다

 

두 수 a,b가 들어왔을 때 우리는 무조건 작은수에서 큰수로 갈 것이다

그럼 위에서 아래로 내려오면 되는데 이때 삼각형을 정삼각형으로 l,r 두 방향으로 내려온다

 

현재 dep에서의 index를 사용하면 l,r을 구하기 쉽다!

dep는 lower_bound를 통해 구하면 된다

 

기본적으로 무조건 dep차이만큼은 가야한다!

큰 수와 같은 dep까지 왔을 때가 중요하다!

 

1) l<maxn 이라면 정삼각형 범위보다 안쪽에 있으므로 +(maxn-l)

2) maxn<r 이라면 +(r-maxn)

 

만큼 더해주면 된다!

 

만약 그 사이의 범위라면 dep차이가 답이다

두 개의 점을 포함하는 정삼각형을 그려보면 무조건 한 변의 길이로 갈 수 있다!

 

이상한 피라미드속의 삼각형이였다..!! 

 

간만에 하니 어렵다..!!

 

[소스코드]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#include <iostream>
#include <algorithm>
using namespace std;
int psum[222];
 
int depth(int num){
    return lower_bound(psum,psum+200,num) - psum;
}
 
int main(){
    for(int i=1;i<=200;i++) psum[i] = psum[i-1]+i;
    int tc; scanf(" %d",&tc); int c=1;
    while(tc--){
        int a,b; scanf(" %d %d",&a,&b);
        int maxn = max(a,b), minn = min(a,b);
        int dep = depth(minn), target = depth(maxn);
        if(dep == target) printf("#%d %d\n",c++,abs(maxn - minn));
        else {
            int index = psum[dep] - minn;
            int ans = target - dep;
            int r = psum[target] - index;
            index = dep - index;
            int l = psum[target-1+ index;
            if(maxn>r) ans+=(maxn-r);
            if(maxn<l) ans+=(l-maxn);
            printf("#%d %d\n",c++,ans);
        }
    }
}