atcoder#AGC022A. [AGC022A] Diverse Word

[AGC022A] Diverse Word

Score : 300300 points

Problem Statement

Gotou just received a dictionary. However, he doesn't recognize the language used in the dictionary. He did some analysis on the dictionary and realizes that the dictionary contains all possible diverse words in lexicographical order.

A word is called diverse if and only if it is a nonempty string of English lowercase letters and all letters in the word are distinct. For example, atcoder, zscoder and agc are diverse words while gotou and connect aren't diverse words.

Given a diverse word SS, determine the next word that appears after SS in the dictionary, i.e. the lexicographically smallest diverse word that is lexicographically larger than SS, or determine that it doesn't exist.

Let X=x1x2...xnX = x_{1}x_{2}...x_{n} and Y=y1y2...ymY = y_{1}y_{2}...y_{m} be two distinct strings. XX is lexicographically larger than YY if and only if YY is a prefix of XX or xj>yjx_{j} > y_{j} where jj is the smallest integer such that xjyjx_{j} \neq y_{j}.

Constraints

  • 1S261 \leq |S| \leq 26
  • SS is a diverse word.

Input

Input is given from Standard Input in the following format:

SS

Output

Print the next word that appears after SS in the dictionary, or -1 if it doesn't exist.

atcoder
atcoderb

atcoderb is the lexicographically smallest diverse word that is lexicographically larger than atcoder. Note that atcoderb is lexicographically smaller than b.

abc
abcd
zyxwvutsrqponmlkjihgfedcba
-1

This is the lexicographically largest diverse word, so the answer is -1.

abcdefghijklmnopqrstuvwzyx
abcdefghijklmnopqrstuvx