打印

看了下今年小学生计算机试题,发现自己还不如小学生了

[复制链接]
379|3
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
kls|  楼主 | 2020-9-28 19:43 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
【问题描述】
小明有一个字符串,由小写英文字母组成。
小明准备对他的字符串进行改造,改造的方法是删除字符串中间的一部分字
符。小明希望改造完后,新的字符串中的相邻字符都满足左边的字符小于等于右
边的字符(a < b < … < z)。
例如,对于字符串 happy,小明可以删除第一个字母,变成 appy,满足要
求。或者小明删除第二字母,变成 hppy,也满足要求。小明还有其他方法使得
结果满足要求。
再如,对于字符串 autumn,可以删除3 个字母变成 tmn,或者删除4 个
字母变成 at。其他满足要求的方案还有很多。
小明想知道,对于一个字符串,至少要删除多少个字母能满足要求。
【输入格式】
从文件trans.in 中输入数据。
输入一行包含一个字符串。
【输出格式】
输出到文件trans.out 中。
输出一行,包含一个整数,表示最少要删除的字母个数。
【样例输入】
happy
【样例输出】
1
【样例输入】
autumn
【样例输出】
3

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





限制半个小时做出来,考试时间总共120分钟,5道C++题,这是其中一道。

看了感觉自己还不如小学生,

使用特权

评论回复

相关帖子

沙发
kls|  楼主 | 2020-9-28 19:44 | 只看该作者
发一组测试数据,这组测试数据的结果是722
测试数据如下
adcbbdeecdeabbdabdabedabebeddcaaeecaaceeaadeceecccededadcdcceaaceddcdbdabdedddbbdaabeedabacccdebedacbcbabcbaddbecbaabdeebeacecdbaabdbedecdeddcccdeebbcecaddebaddcebedaeaeddbdcbccdcddbbebcceeccadbccadaeaabdbcdddccbbabeadccdbcabcbdccddaaebbaeceacedbbaccacaacabedcccdbaddbaeabaaaceddeaeaeccdadebcbedeabcbcdaeeaeddaacbcaacbecacacdddddbeabeacdacebcedbaecabaccaeaedbaddaabdbcdeadbbedcbdaaccdcbcdcbceecabccabeccbbbbdcbbbdadbbdbaaaceaaeddebdeeebaacbdecebcccbddbeeebcdcbacbcdacbbadcceeaecbbdaaadcceececacbcbdebaaaeabbaacceadadccbdadcbaaceabbddeecaeeddbcdcdabbcdbbacebbbebaeadccdabccdcbeceacaceaadeccceddbccebabcbaeaebddddbecdcbceadeaeabecbcbcacabeaecaaecddaecbacecaaaeddbebadbccbaaabdecbecbdcaacdaddbbecadeaabeaeecbadaecbeabcadaaedbcecaccadbadadbcabcbedabbcecedeebaccdcbaacecaacedebcdddcbaccadbcaeaccdebbadbcbacccdbdbcbbdcaddacababacddaeeaeccebcdbcaaabbcabcbbadcedcacdcbecdebddaaeeaedacacdcebcbbcedcaecbcbdabebbddaccbceedecdcebbeeaacabecaecdadbbdcbdcaebcbcdcbc

使用特权

评论回复
板凳
kls|  楼主 | 2020-9-28 19:46 | 只看该作者
再如,对于字符串 autumn,可以删除3 个字母变成 tmn
题目说明这里应该是有点表述不准确,我原样复制的。哪位有余力,有脑力,可以测试下,看多长时间做出来

使用特权

评论回复
地板
kls|  楼主 | 2020-9-28 19:47 | 只看该作者
有兴趣的可以找我要另外9组测试数据和答案

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

kls

66

主题

424

帖子

0

粉丝