POJ No.3617-Best Cow Line(字典序最小问题)
给定长度为N的字符串S,要构造一个长度为N的字符串T。起初,T是一个空串,随后反复进行下列任一操作。
从S的头部删除一个字符,加到T的尾部
从S的尾部删除一个字符,加到T的尾部
目标是要构造字典序尽量可能小的字符串T。
(字典序:字典序是指从前到后比较两个字符串大小的方法。首先比较第1个字符,如果不同则第1个字符较小的字符串更小,如果相同则继续比较第2个字符……如此继续,来比较整个字符串的大小。)
限制条件:字符串S只包含大写英文字母
输入
S=”ACDBCB”
输出
ABCBCD
从字典序的性质上看,无论T的末尾有多大,只要前面部分的较小就可以。
不断取S的开头和末尾中较小的一个字符放到T的末尾?
若开头和结尾字符串相同?就要比较下一个字符的大小。
按照字典序比较S和将S反转后的字符串S’
如果S较小,就从S的开头取出一个文字,追加到T的末尾。
如果S’较小,就从S’的开头取出一个文字,追加到T的末尾。
(若相同则取哪个都可以)
import java.util.Scanner;
public class BestCowLine
{
public static void main(String[] args) {
Scanner cin = new Scanner(System.in);
String str = cin.nextLine();
int a = 0;
int b = str.length() - 1;
while (a <= b) {
boolean left = false;
for (int i = 0; a + i <= b; i++)
if (str.charAt(a + i) < str.charAt(b - i)) {
left = true;
break;
} else if (str.charAt(a + i) > str.charAt(b - i)) {
left = false;
break;
}
if (left)
System.out.print(str.charAt(a++));
else
System.out.print(str.charAt(b--));
}
}
}