Home Programmers - 이진 변환 반복하기
Post
Cancel

Programmers - 이진 변환 반복하기

이진 변환 반복하기 - lv.2

문제

0과 1로 이루어진 어떤 문자열 x에 대한 이진 변환을 다음과 같이 정의합니다.

  1. x의 모든 0을 제거합니다.
  2. x의 길이를 c라고 하면, x를 “c를 2진법으로 표현한 문자열”로 바꿉니다.

예를 들어, x = “0111010”이라면, x에 이진 변환을 가하면 x = “0111010” -> “1111” -> “100” 이 됩니다.

0과 1로 이루어진 문자열 s가 매개변수로 주어집니다. s가 “1”이 될 때까지 계속해서 s에 이진 변환을 가했을 때, 이진 변환의 횟수와 변환 과정에서 제거된 모든 0의 개수를 각각 배열에 담아 return 하도록 solution 함수를 완성해주세요.

제한사항

  • s의 길이는 1 이상 150,000 이하입니다.
  • s에는 ‘1’이 최소 하나 이상 포함되어 있습니다.

입출력 예

sresult
“110010101001”[3,8]
“01110”[3,3]
“1111111”[4,1]

입출력 예 #1

  • “110010101001”이 “1”이 될 때까지 이진 변환을 가하는 과정은 다음과 같습니다.
회차이진변환 이전 제거할 0의 개수0 제거 후 길이이진 변환 결과
1“110010101001”66“110”
2“110”12“10”
3“10”11“1”
  • 3번의 이진 변환을 하는 동안 8개의 0을 제거했으므로, [3,8]을 return 해야 합니다.

입출력 예 #2

  • “01110”이 “1”이 될 때까지 이진 변환을 가하는 과정은 다음과 같습니다.
회차이진변환 이전 제거할 0의 개수0 제거 후 길이이진 변환 결과
1“01110”23“11”
2“11”02“10”
3“10”11“1”
  • 3번의 이진 변환을 하는 동안 3개의 0을 제거했으므로, [3,3]을 return 해야 합니다.

입출력 예 #3

  • “1111111”이 “1”이 될 때까지 이진 변환을 가하는 과정은 다음과 같습니다.
회차이진변환 이전 제거할 0의 개수0 제거 후 길이이진 변환 결과
1“1111111”07“111”
2“111”03“11”
3“11”02“10”
4“10”11“1”
  • 4번의 이진 변환을 하는 동안 1개의 0을 제거했으므로, [4,1]을 return 해야 합니다.

풀이

  • String
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
30
31
32
33
#include <string>
#include <vector>
#include <iostream>
#include <bitset>

using namespace std;

vector<int> solution(std::string s) {
    int count = 0;
    int count_erased_zero = 0;
    while (s != "1") {
        std::string sub;
        for (const char& c : s) {
            if (c != '0') {
                sub.push_back(c);
            } else {
                count_erased_zero++;
            }
        }

        uint64_t value = std::bitset<64>(sub.size()).to_ullong();
        std::string temp = std::bitset<64>(value).to_string();

        const auto first_digit = temp.find('1');
        if(first_digit != std::string::npos) {
            s = temp.substr(first_digit);
        }

        count++;
    }

    return {count, count_erased_zero};
}
This post is licensed under CC BY 4.0 by the author.

Programmers - JadenCase 문자열 만들기

Distributed Systems - 분산 시스템 소개