PivotOJ

XOR 최대

시간 제한: 2000ms메모리 제한: 1024MB출처: KOI 2024 2차BOJ 32073

문제

어떤 문자열에서 연속한 위치에 있는 1개 이상의 문자를 선택해 순서를 유지한 채로 나열해서 얻을 수 있는 문자열을 그 문자열의 부분문자열이라 한다. 예를 들어, 001001X=10011X = 1\underline{001}1의 부분문자열이지만, Y=10101Y = 10101의 부분문자열은 아니다.

음이 아닌 두 정수 A,BA, B배타적 논리합 ABA \oplus B는 다음과 같이 정의된다.

  • 이진법으로 생각했을 때, AA2k2^k의 자릿수와 BB2k2^k의 자릿수가 서로 다르면 ABA \oplus B2k2^k의 자릿수가 11이고, 같으면 ABA \oplus B2k2^k의 자릿수가 00이다. (단, k0k \ge 0)
  • 예를 들어 121012 \oplus 1012=1100(2),10=1010(2)12 = 1100_{(2)}, 10 = 1010_{(2)}이므로 1100(2)1010(2)=0110(2)=61100_{(2)} \oplus 1010_{(2)} = 0110_{(2)} = 6이다.

0011로만 구성된 길이가 NN인 문자열 SS가 주어진다.

당신은 SS의 부분문자열 s1,s2s_1, s_2를 선택해서 만들 수 있는 g(s1,s2)g(s_1, s_2)의 최댓값을 계산해야 한다. g(s1,s2)g(s_1, s_2)는 다음과 같이 정의되는 함수이다:

  • SS의 부분문자열 ss에 대해, f(s)f(s)의 값은 ss를 이진법으로 해석했을 때의 값이다. 예를 들어, 만약 s=11010s = 11010이면 f(s)=26f(s) = 26이다.
  • g(s1,s2)g(s_1, s_2)f(s1)f(s_1)f(s2)f(s_2)의 배타적 논리합이다.

이때 s1s_1s2s_2가 서로 다를 필요는 없다. 즉, s1s_1s2s_2SS에서 일부가 겹쳐도 되고, 완전히 같은 문자열이어도 된다.

0011로만 구성된 문자열 SS가 주어지면, 가능한 g(s1,s2)g(s_1, s_2)의 최댓값을 구하는 프로그램을 작성하라.

입력

첫 번째 줄에 테스트 케이스의 개수 TT가 주어진다.

각 테스트 케이스마다, 첫 번째 줄에 문자열의 길이 NN, 두 번째 줄에 0011로만 구성된 길이가 NN인 문자열 SS가 주어진다.

출력

각 테스트 케이스마다 가능한 g(s1,s2)g(s_1, s_2)의 최댓값을 이진법으로 한 줄에 하나씩 출력한다. 단, 정답 앞에 필요 없는 00은 출력하지 않는다.

예제

예제 1

입력
4
3
010
5
10101
5
00100
5
11111
출력
11
11111
110
11110

예제 2

입력
4
2
00
2
01
2
10
2
11
출력
0
1
11
10
코드를 제출하려면 로그인하세요.