codeforces#P1654B. Prefix Removals

Prefix Removals

Description

You are given a string $s$ consisting of lowercase letters of the English alphabet. You must perform the following algorithm on $s$:

  • Let $x$ be the length of the longest prefix of $s$ which occurs somewhere else in $s$ as a contiguous substring (the other occurrence may also intersect the prefix). If $x = 0$, break. Otherwise, remove the first $x$ characters of $s$, and repeat.

A prefix is a string consisting of several first letters of a given string, without any reorders. An empty prefix is also a valid prefix. For example, the string "abcd" has 5 prefixes: empty string, "a", "ab", "abc" and "abcd".

For instance, if we perform the algorithm on $s =$ "abcabdc",

  • Initially, "ab" is the longest prefix that also appears somewhere else as a substring in $s$, so $s =$ "cabdc" after $1$ operation.
  • Then, "c" is the longest prefix that also appears somewhere else as a substring in $s$, so $s =$ "abdc" after $2$ operations.
  • Now $x=0$ (because there are no non-empty prefixes of "abdc" that also appear somewhere else as a substring in $s$), so the algorithm terminates.

Find the final state of the string after performing the algorithm.

The first line contains a single integer $t$ ($1 \le t \le 10^4$) — the number of test cases.

This is followed by $t$ lines, each containing a description of one test case. Each line contains a string $s$. The given strings consist only of lowercase letters of the English alphabet and have lengths between $1$ and $2 \cdot 10^5$ inclusive.

It is guaranteed that the sum of the lengths of $s$ over all test cases does not exceed $2 \cdot 10^5$.

For each test case, print a single line containing the string $s$ after executing the algorithm. It can be shown that such string is non-empty.

Input

The first line contains a single integer $t$ ($1 \le t \le 10^4$) — the number of test cases.

This is followed by $t$ lines, each containing a description of one test case. Each line contains a string $s$. The given strings consist only of lowercase letters of the English alphabet and have lengths between $1$ and $2 \cdot 10^5$ inclusive.

It is guaranteed that the sum of the lengths of $s$ over all test cases does not exceed $2 \cdot 10^5$.

Output

For each test case, print a single line containing the string $s$ after executing the algorithm. It can be shown that such string is non-empty.

Samples

6
abcabdc
a
bbbbbbbbbb
codeforces
cffcfccffccfcffcfccfcffccffcfccf
zyzyzwxxyyxxyyzzyzzxxwzxwywxwzxxyzzw
abdc
a
b
deforces
cf
xyzzw

Note

The first test case is explained in the statement.

In the second test case, no operations can be performed on $s$.

In the third test case,

  • Initially, $s =$ "bbbbbbbbbb".
  • After $1$ operation, $s =$ "b".

In the fourth test case,

  • Initially, $s =$ "codeforces".
  • After $1$ operation, $s =$ "odeforces".
  • After $2$ operations, $s =$ "deforces".