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

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--));
		}
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值