POJ No.3617-Best Cow Line(字典序最小问题)

来源:互联网 发布:李荣浩后羿知乎 编辑:程序博客网 时间:2024/04/30 19:23

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++));elseSystem.out.print(str.charAt(b--));}}}


0 0