80min AK。好难,秋招目前写过最难的笔试。T1Description给定一个长度为的排列,要求构造一个长度相同的排列,满足,且的字典序最小。Solution贪心构造,用一个set或者堆来维护剩余没填入b的数里面的最小值和次小值,如果当前填入最小值会导致,那么就填入次小值;另外,在只剩下两个数没填的时候,直接填入最小值可能次小值正好使得,特判这种情况。时间复杂度。T2Description给定字符串和,且字符串只包含小写字母,可以对进行任意次操作,每次操作将中的小写字母全部修改为小写字母,比如将中的修改成就变成,问能不能将变成。Solution如果与相同则肯定是Yes,否则check 2;考虑每次操作只会让可能让原先不同的字符变得相同,而不可能将相同的字符分开,所以check一下中的每个字符的位置在中是不是相同字符,如果不是则肯定是No否则check 3;最后考虑如果和都包含全部的26个字母,那么肯定是No,否则是Yes。时间复杂度。T3Description给定行列的只包含小写字母的字符矩阵,求有多少个子矩阵满足每个字母最多出现一次。Solution考虑对行枚举固定的范围,对列用双指针维护寻找答案,枚举行范围的时候可以想到其长度一定不超过26,然后对该范围内每一列状压一下即可。时间复杂度。其实还可以继续优化,考虑枚举长度,就可以通过的状压来直接得到的状压,像这样处理复杂度为。T4Description给定一个长度为的正整数,现在要恰好修改其中的个数位,使得这个数能被75整除,问方案数的值。Solution直接dp,设表示从高到低前个数位表示的数字修改次后得到的数在意义下值为的方案数,那么转移显然分为修改当前数字和不修改当前数字两种。时间复杂度为,然后剪枝一下,当枚举的前一个状态dp值为0时不进行转移。需要特别注意的是的空间复杂度过大,考虑将第一维用滚动数组滚掉,空间复杂度降为,可以通过此题。
点赞 19
评论 8
全部评论

相关推荐

昨天 14:30
中南大学
点赞 评论 收藏
分享
投递米哈游等公司10个岗位
点赞 评论 收藏
分享
天天困啊:个人建议第一点就是熟悉Redis这里不要这么写,写上Redis比较核心的技术,什么缓存一致性,雪崩穿透击穿那些,掌握cos其实不用写在专业技能里这个你做了鱼皮的这个项目面试官默认应该认为你应该懂了,鱼皮这个项目核心挺多建议多啃啃,在做一个鱼皮的微服务项目俩项目在一起比较好哦
你的简历改到第几版了
点赞 评论 收藏
分享
为啥美团有的笔试可以AI做题啊。。。。我们怎么就不行
碧海蓝涛:因为ai也做不出来
投递美团等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务