Warning: Uninitialized string offset 1 in /usr/local/apache2/htdocs/include/ParsedownExtended/ParsedownExtended.php on line 812 이진수
[2021 SCPC 1차 예선]
이진수
\(n\) 비트로 구성된 이진수 \(A=a_1 a_2 … a_n\) (\(a_i\)는 0 또는 1)와 자연수 \(t\) 가 주어질 때, \(A\)로부터 아래와 같은 연산을 통해 새로운 이진수 \(B=b_1 b_2 …bn\) 를 만든다.
1. 초기에 \(b_i\ (1 ≤i ≤n)\) 는 모두 0으로 리셋한다.
2. 만약 \(i>t\) 이고 \(a_{i-t}=1\) 이면 \(b_i \)는 1로 둔다.
3. 만약 \(i≤n-t\) 이고 \(a\{i+t}=1\) 이면 \(b_i\) 는 1로 둔다.
예를 들어, 아래 그림에서 보인 것처럼 9 비트로 구성된 이진수 \(A=100100101\) 이고 \(t=2\) 인 경우, 변환을 통해 새로운 이진수 \(B=011011101\) 을 얻을 수 있다.
변환된 이진수 \(B\)와 자연수 \(t\)가 주어질 때, 이 정보로부터 역으로 \(A\)를 유추하는 프로그램을 작성하고자 한다.
예를 들어, 그림에서 보인 것처럼 \(B=011011101\) 이고 \(t=2\) 라면 가능한 \(A\)의 값은 \(100100101,\ 100110101,\ 000110100\) 등이다.
주어진 이진수 \(B\)와 자연수 \(t\)로부터 유추 가능한 \(A\)가 둘 이상일 경우, \(A\)의 값을 이진수로 보았을 때, 가장 작은 값을 출력하는 프로그램을 작성하시오. 주어진 이진수 \(B\)와 자연수 \(t\) 로부터 유추 가능한 \(A\)가 존재하지 않는 경우는 주어지지 않는다.
그림 1
제한시간: 전체 테스트 케이스는 64개 이하이며, 전체 수행 시간은 1초 이내. (Java 2초 이내)
제한 시간을 초과하면 제출한 소스코드의 프로그램이 즉시 종료되며,
그때까지 출력한 내용이 파일에 저장되지 않아 점수가 제대로 반영되지 않을 수 있습니다.
그러나, 제한 시간을 초과하더라도 테스트 케이스를 1개 그룹 이상 통과하였다면 '부분 점수(0< 점수< 만점)'를 받을 수 있으며,
이를 위해서는, C / C++ 에서 "printf 함수" 사용할 경우, 프로그램 시작부분에서 "setbuf(stdout, NULL);"를 한번만 사용하십시오.