60028 XOR 최대

시간 제한: 2초 메모리 제한: 1024MB

문제

어떤 문자열에서 연속한 위치에 있는 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은 출력하지 않는다.

제한

  • 주어지는 모든 수는 정수이다.
  • 1T1001 \le T \le 100
  • 2N1072 \le N \le 10^7
  • 모든 테스트 케이스에서 NN의 합 107\le 10^7
  • SS0011로만 이루어진 길이가 NN인 문자열이다.

서브태스크

117N30N \le 30, 모든 테스트 케이스에서 NN의 합 300\le 300
220N200N \le 200, 모든 테스트 케이스에서 NN의 합 2000\le 2000
313N3000N \le 3\,000, 모든 테스트 케이스에서 NN의 합 30000\le 30\,000
412N2×105N \le 2 \times 10^5, 모든 테스트 케이스에서 NN의 합 2×106\le 2 \times 10^6
538추가 제약 조건 없음.

예제 입출력

예제 입력 1
4
3
010
5
10101
5
00100
5
11111
예제 출력 1
11
11111
110
11110
예제 입력 2
4
2
00
2
01
2
10
2
11
예제 출력 2
0
1
11
10

출처

올림피아드 한국정보올림피아드 KOI 2024 2차 중등부 3번 고등부 2번
solution.cpp
에디터 불러오는 중...