题库 信息学奥赛题库 题目列表 字符串改造(trans.cpp)【问题描述】小明有一个字符串...
问答题

字符串改造(trans.cpp)

【问题描述】

小明有一个字符串,由小写英文字母组成。

小明准备对他的字符串进行改造,改造的方法是删除字符串中间的一部分字符。

小明希望改造完后,新的字符串中的相邻字符都满足左边的字符小于等于右边的字符(a < b < … < z)。  

 

例如,对于字符串 happy,小明可以删除第一个字母,变成 appy,满足要求。或者小明删除第二字母,变成 hppy,也满足要求。小明还有其他方法使得结果满足要求。

再如,对于字符串 autumn,可以删除 3 个字母变成 tmn,或者删除 4 个字母变成 at。

其他满足要求的方案还有很多。

小明想知道,对于一个字符串,至少要删除多少个字母能满足要求。

 

【输入格式】

从文件 trans.in 中输入数据。

输入一行包含一个字符串。

 

【输出格式】

输出到文件 trans.out 中。

 

输出一行,包含一个整数,表示最少要删除的字母个数。

 

【样例输入】

happy

 

【样例输出】

1

 

【样例输入】

autumn

 

【样例输出】

3

 

【评测用例规模与约定】

注意:以下规模是评测时输入数据一定会满足的限制,在你的程序中不需要对这些限制进行检查。

对于 30%的评测用例,字符串的长度不超过 20;

对于 60%的评测用例,字符串的长度不超过 1000;

对于 80%的评测用例,字符串的长度不超过 10000;

对于所有评测用例,字符串的长度不超过 100000。

题目信息
完善程序 2020年 初赛
-
正确率
0
评论
309
点击