알고리즘/프로그래머스 1단계

프로그래머스 - 가까운 수 - C++

게임만드는학생 2023. 8. 13. 14:27

https://school.programmers.co.kr/learn/courses/30/lessons/120890

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

#include <string>
#include <vector>
#include <cmath>
#include <algorithm>
using namespace std;

int solution(vector<int> array, int n) {
    int answer = 0;
    vector<vector<int>> a (100,vector<int>());
    
    for(int i=0;i<array.size();i++)
    {
        a[abs(n-array[i])].push_back(array[i]);
    }
    
    for(int i=0;i<100;i++)
    {
        if(a[i].size()!=0)
        {
            sort(a[i].begin(),a[i].end());
            return a[i][0];
        }
    }
    
    return answer;
}

 

 

설명

abs(), sort(), 2차원 벡터 vector<vector<int>> 

array 배열에서 n 과 가장 가까운 수를 찾는 문제이다. 

원소가 1 에서 100까지니 차이는 0 ~ 99 까지이다. 

2차원 vector로  array[i] - n 의 절댓값이 i 일때  

a[abs(array[i] - n)].push_back(array[i]);

위 코드처럼 a[i] 에 array[i] 를 삽입하였다. 

예를 들어, array[i] 가 5 고 n 이 3 이면, array[i] - n 의 절댓값은 2 이다. 따라서 a[2] 에 5를 삽입한다. 

 

이런식으로 n과의 차이 즉, 거리에 따라 모든 숫자를 분류한다. 

그리고 a를 0부터 보며 a[i] 의 size가 1 이상인 것을 찾고 그 중 가장 작은 수를 찾으면 된다. 

 

a를 0부터 보는 이유는 a[0] 에는 n 과의 차이가 0인 즉, 제일 가까운 수가 들어있기 때문이다. 

 

ex) n이 5일 때, a[1] => { 6,4 } 이면 sort 를 통해 오름차순으로 정렬하고 a[1][0] 을 리턴하면

가장 가까운 수들 중 가장 작은 수를 찾을 수 있다.