본문 바로가기

문과 코린이의, [C. C++] 기록/C++ 백준 문제풀이

[문과 코린이의 IT 기록장] C++ 백준 문제풀이 - 2진수 8진수 (1373)

반응형

[문과 코린이의 IT 기록장] C++ 백준 문제풀이 - 2진수 8진수 (1373)

[문과 코린이의 IT 기록장] C++ 백준 문제풀이 - 2진수 8진수 (1373)

 


 

1373번: 2진수 8진수

첫째 줄에 2진수가 주어진다. 주어지는 수의 길이는 1,000,000을 넘지 않는다.

www.acmicpc.net

[ 문제 ]

2진수가 주어졌을 때, 8진수로 변환하는 프로그램을 작성하시오.

[ 입력 ]

첫째 줄에 2진수가 주어진다. 주어지는 수의 길이는 1,000,000을 넘지 않는다.

[ 출력 ]

첫째 줄에 주어진 수를 8진수로 변환하여 출력한다.

 


[ 코드 ]

#include<iostream>
using namespace std;

int main() {
	ios_base::sync_with_stdio(false);
	cin.tie(nullptr);

	string input; // 2진수 input
	cin >> input;

	int n = input.size();

	// 길이를 3개씩 나눴을 때, 앞에 한 자리가 남는다면
	if (n%3 == 1)
	{
		cout << input[0];
	}
	// 길이를 3개씩 나눴을 때, 앞에 두 자리가 남는다면
	else if (n%3 == 2)
	{
		cout << (input[0] - '0') * 2 + (input[1] - '0');
		// 숫자 형태의 문자를 정숫값으로 변환하려면, 해당 문자에 '0'을 빼면 됨
		// '1'의 ASCII코드 값은 49이고, '0'의 ASCII 코드 값은 48이기 때문.
		// 8진수로 변환하기 위해서는, 해당 문자의 연산이 필요하기 때문에 이렇게 하는것
	}
	
	// 길이가 모두 3개씩 나눠진다면
	for (int i = n % 3; i < n; i += 3)
	{
		cout << (input[i] - '0') * 4 + (input[i + 1] - '0') * 2 + (input[i + 2] - '0');
	}

	cout << '\n';

	return 0;
}

* 유의사항
- 아직 공부하고 있는 문과생 코린이가, 정리해서 남겨놓은 정리 및 필기노트입니다.
- 정확하지 않거나, 틀린 점이 있을 수 있으니, 유의해서 봐주시면 감사하겠습니다.
- 혹시 잘못된 점을 발견하셨다면, 댓글로 친절하게 남겨주시면 감사하겠습니다 :)
반응형