ZYB loves binary strings (strings that only contains `0' and `1'). And he loves equalbinarystringstextit{equal binary strings}equalbinarystrings more, where the number of `0' and the number of `1' in
ZYB loves binary strings (strings that only contains `0' and `1'). And he loves equal binary stringstextit{equal binary strings}equal binary strings more, where the number of `0' and the number of `1' in the string are equal. ZYB wants to choose a substring from an original string T T T so that it is an equal binary stringtextit{equal binary string}equal binary string with the longest length possible. He also wants to choose a subsequence of T T T which meets the same requirements. A string v v v is a substring of a string w w w if v v v is empty, or there are two integers l l l and r (1≤l≤r≤∣w∣)r (1 le l le r le |w|)r (1≤l≤r≤∣w∣) such that v=wlwl+1⋯wrv=w_lw_{l+1}cdots w_rv=wlwl+1⋯wr. A string v v v is a subsequence of a string w w w if it can be derived from w w w by deleting any number (including zero) of characters without changing the order of the remaining characters. For simplicity, you only need to output the maximum possible length. Note that the empty string is both a substring and a subsequence of any string.