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

프로그래머스 - 3진법 뒤집기 - C++

게임만드는학생 2023. 10. 23. 11:59

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

 

프로그래머스

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

programmers.co.kr

 

#include <string>
#include <vector>
#include <algorithm>

using namespace std;

int solution(int n) {
    int answer = 0;
    string a="";
    
    while(n>0)
    {
        a+=(char)(n%3);
        n/=3;
    }
    
    answer=0;
    int pow=1;
    for(int i=a.length()-1;i>=0;i--)
    {
        answer += (int)a[i]*pow;
        pow*=3;
    }
    
    return answer;
}

 

설명

이 문제는 주어진 10진수를 3진법으로 바꾼후 3진수를 뒤집어서 다시 10진수로 바꾸는 문제이다. 

 

먼저 10진수를 3진수로 바꾸는데 3진수를 문자열로 표시한다. 

while(n>0)
    {
        a+=(char)(n%3);
        n/=3;
    }

예를 들어, 45 를 3진수로 나타내면 1200 이지만 

위 코드처럼 하면 0021 로 a 문자열에 저장이 된다. 

 

따라서 1부터 역순으로 계산하여 10진수로 바꾸면 답이 도출된다. 

 

1* 3^0 + 2*3^1 + 0*3^2 + 0*3^3 으로 식을 계산하면 된다. 

즉, i*3^pow 로 항을 정의할 수있다.

int pow=1;
    for(int i=a.length()-1;i>=0;i--)
    {
        answer += (int)a[i]*pow;
        pow*=3;
    }

여기서 변수 i를 문자열의 맨뒤에서부터 0까지 역순으로 돌게하면 i에 대입할 수 있고

pow는 1부터 시작하면 1,3,3^2 이런식으로 대입할 수 있다.

이 때, pow는 1부터 시작하여 항을 계산 후 3을 곱해준다. 

 

그리고 최종값인 answer를 반환한다.