308051: CF1458D. Flip and Reverse

Memory Limit:512 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Flip and Reverse

题意翻译

给定01字符串 $s$,现在你能进行若干次操作,对于每一次操作: - 选择字符串 $s$ 的连续的一段子串,要求这段子串必须包含同样数量的字符 `0` 与 `1`. - 把该子串的所有字符转换,即所有字符 `0` 换为 `1`,字符 `1` 换为 `0`. - 把选中的子串反转. 比如设字符串 $s=$ `00111011`. 我们可以选择前六个字符 `001110` 进行操作,这个操作合法是因为 `0` 和 `1` 的数量一致,选择 `00111`,`0` 等都是不合法的. 然后把这六个字符转换,变为 `110001`. 最后反转整个字串,变为 `100011`. 最终经过一次操作,我们就可以得到字符串 `10001111`.现在给定字符串 $s$,求经过若干次操作后字典序最小的字符串. $T$ 组询问.保证 $1\leq\sum len(s)\leq5\times10^5.$

题目描述

You are given a string $ s $ of 0's and 1's. You are allowed to perform the following operation: 2. choose a non-empty contiguous substring of $ s $ that contains an equal number of 0's and 1's; 3. flip all characters in the substring, that is, replace all 0's with 1's, and vice versa; 4. reverse the substring. For example, consider $ s $ = 00111011, and the following operation: 6. Choose the first six characters as the substring to act upon: 00111011. Note that the number of 0's and 1's are equal, so this is a legal choice. Choosing substrings 0, 110, or the entire string would not be possible. 7. Flip all characters in the substring: 11000111. 8. Reverse the substring: 10001111. Find the lexicographically smallest string that can be obtained from $ s $ after zero or more operations.

输入输出格式

输入格式


The first line contains a single integer $ T $ ( $ 1 \leq T \leq 5 \cdot 10^5 $ ) — the number of test cases. Each of the following $ T $ lines contains a single non-empty string — the input string $ s $ for the respective test case. All strings consist of characters 0 and 1, and their total length does not exceed $ 5 \cdot 10^5 $ .

输出格式


For each test case, on a separate line print the lexicographically smallest string that can be obtained from $ s $ after zero or more operations.

输入输出样例

输入样例 #1

3
100101
1100011
10101010

输出样例 #1

010110
0110110
10101010

说明

In the first test case a single operation should be applied to the entire string. In the second test case two operations are needed: 0111001, 0110110. In the third test case the string stays the same after any operation.

Input

题意翻译

给定01字符串 $s$,现在你能进行若干次操作,对于每一次操作: - 选择字符串 $s$ 的连续的一段子串,要求这段子串必须包含同样数量的字符 `0` 与 `1`. - 把该子串的所有字符转换,即所有字符 `0` 换为 `1`,字符 `1` 换为 `0`. - 把选中的子串反转. 比如设字符串 $s=$ `00111011`. 我们可以选择前六个字符 `001110` 进行操作,这个操作合法是因为 `0` 和 `1` 的数量一致,选择 `00111`,`0` 等都是不合法的. 然后把这六个字符转换,变为 `110001`. 最后反转整个字串,变为 `100011`. 最终经过一次操作,我们就可以得到字符串 `10001111`.现在给定字符串 $s$,求经过若干次操作后字典序最小的字符串. $T$ 组询问.保证 $1\leq\sum len(s)\leq5\times10^5.$

加入题单

上一题 下一题 算法标签: