2023华为OD机试真题-字符串解密(JAVA、Python、C++)

根据给定的加扰字符串和参考字符串,找出有效子串,使其不同字母数量最接近参考字符串,同时字典序最大。示例中,从加扰字符串中去除加扰子串后,找到满足条件的子串。
摘要由CSDN通过智能技术生成

题目描述:
    给定两个字符串string1和string2。
    string1是一个被加扰的字符串。string1由小写英文字母('a'~'z')和数字字符('0'~'9')组成,而加扰字符串由'0'~'9'、'a'~'f'组成。string1里面可能包含0个或多个加扰子串,剩下可能有0个或多个有效子串,这些有效子串被加扰子串隔开。
    string2是一个参考字符串,仅由小写英文字母('a'~'z')组成。
    你需要在string1字符串里找到一个有效子串,这个有效子串要同时满足下面两个条件:
    (1)这个有效子串里不同字母的数量不超过且最接近于string2里不同字母的数量,即小于或等于string2里不同字母的数量的同时且最大。
    (2)这个有效子串是满足条件(1)里的所有子串(如果有多个的话)里字典序最大的一个。
    如果没有找到合适条件的子串的话,请输出"Not Found"

示例:
输入字符串string1为"thisisanewday111forme",输入字符串string2为"good"。string1里有效子串和加扰子串分割后可表示为:"thisis"+"a"+"n"+"e"+"w"+"da"+"y"+"111f"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值