京东2019秋招前端Web笔试编程题第一题

我数据结构和算法很垃圾,本以为一道都做不出来,结果还是通过自己的蠢方法做了出来

但是一开始的有点小问题,考试结束才想起不太对劲。。。
现在已经修改下小错误,因为已经没有错了,有错欢迎指出来!


题目如下:




Python3 代码如下:

代码看上去很多,其实有很多注释,而且其实思路很简单
代码丑陋,上面也说道,我的数据结构和算法很垃圾的,只是有个思路做出这道题,
不喜勿喷……

def min_press(string, length):
    if string.lower() == string:
        return length

    if string.upper() == string:
        return length + 1

    count = 0   # 所需的最小按键数
    flag = False  # 大小写模式标志位,默认一开始为小写(其中小写用False表示,大写用True表示)
    for i in range(length):
        # 特殊情况:到了最后一个元素之后是没有i+2的,会超出索引
        # 所以需要对倒数第二个开始做下特殊处理,这里就一次把最后2个所需按键总数算出来
        # 最后两个只有4种情况,aa(小小),aA(小大),Aa(大小),AA(大大)
        if i == length - 2:
            if not flag:
                # 当前为小写模式,且最后两个为aa(小小),才+2
                if string[i].islower() and string[i+1].islower():
                    count += 2
                # 剩下的3种情况都是+3,可以自行理解下
                else:
                    count += 3
            else:
                # 这里的分析也类似上面的
                if string[i].isupper() and string[i+1].isupper():
                    count += 2
                else:
                    count += 3
            return count

        # 以下为正常情况下
        # 如果当前为小写模式
        if not flag:
            # 考虑下首字符这种特殊情况
            if i == 0:
                i -= 1
            # 如果下一个字母还是小写,直接+1
            if string[i+1].islower():
                count += 1
            # 下一个是大写,再下一个是小写,那就临时切换
            elif string[i+1].isupper() and string[i+2].islower():
                count += 2
            # 下一个是大写,再下一个也是大写,那就永久切换
            elif string[i+1].isupper() and string[i+2].isupper():
                flag = True
                count += 2
        # 如果当前是大写模式
        else:
            # 下一个字母还是大写,直接+1
            if string[i+1].isupper():
                count += 1
            # 下一个是小写,再下一个是大写,那就只是临时切换
            elif string[i+1].islower() and string[i+2].isupper():
                count += 2
            # 下一个是小写,再下一个还是小写,那就永久切换
            elif string[i+1].islower() and string[i+2].islower():
                flag = False
                count += 2
    return count


while True:
    str_len = int(input().strip())
    string = input().strip()
    print(min_press(string, str_len))



#京东##秋招##笔试题目##前端工程师#
全部评论
好了,你就是东哥的兄弟
点赞 回复 分享
发布于 2019-08-24 23:35
你不用应聘前端了,python大厂需要你
点赞 回复 分享
发布于 2019-08-24 23:17

相关推荐

2025-12-08 18:11
曲阜师范大学 Java
程序员花海_:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
头像
01-12 14:44
已编辑
百度_高级研发工程师
今天看到了某平台攻击牛友的帖子,段段今天打算为牛友们说句话,我们的努力到底有没有意义。 (原文复述:感觉牛客就是当年那群做题区毕业了开始找工作还收不住那股味,颇有一种从年级第一掉到年纪第二后抱怨考不上大学的区味)  粗鄙,无礼,傲慢,攻击,在这里我没有看到任何有用的分析,我只看到了屁股决定脑袋的攻击,我只看到了嫉妒和眼红。一、去医院不看病你去逛街吗 去医院你不去看病你去逛街吗?去加油站不加油你去抽烟吗?去部队你不训练战斗技能你去养老吗?来牛客你不努力求职你来干什么来了。 牛客本身就是个求职平台,大家分享有用的知识,分享面经,分享offer,分享求职经验的,来牛客不就干这个来了吗?有什么问题吗?...
给个好点的工作吧啊啊...:不知道我看的是不是和博主同样的帖子,我记得原帖是表达的是有些匿名老是发几十万的offer侮辱价,然后就有牛友觉得凡尔赛了导致后面的评论有些偏激。我觉得这个最近闫学晶那个事情有点类似了,她说他儿子一年只能赚七八十万家庭生活都难以为继,不说普通家庭,多少大厂的程序员都赚不到这个数字,大部分家庭看到这种发言肯定会难受的一p,生活的担子又这么重,人都是需要发泄情绪的,互联网就是个极佳的载体,所以很多人直接就喷她了,人在情绪发泄的时候是不思考的,否则就不叫发泄了。然后还有一个点,段哥假定了这些喷的人全都是“躺平的”,这点可能有失偏颇,很多人一直在努力,但是始终缺乏天时地利人和的某一个条件,这点相信段哥找工作的过程中深有体会。绝大部分人都以结果的失败去否认了努力的全过程,可能只是别人努力的方向错了。就像一次面试,可能你准备了很久,结果面试官就是比较奇葩,一直问没有学习到的领域或知识点,然后有人凭一个挂掉的结果就直接给你扣了一个“躺平”的帽子,觉得挂掉是你不够努力,您心里滋味如何?再说点近点的,我也是od,多少同事深夜无偿加班,涨过一分工资吗?多少外包的技术大牛因为学历被困在外包,连od都进不去,这些人难道不努力吗?只是限制与生活、公司制度等等之类的无奈罢了。说到努力,又想到李家琦79元眉笔事件,这么多年有没有认真工作?有没有涨工资?他嘴里说出来是那么的理所当然,打工牛马都知道“任劳任怨”,“认真工作”真能涨工资?只干活不发声就等着被摘果子吧,企业里永远都是“汇报杰出者”升的最快(当然不是所有企业),这种事情相信段哥包括我甚至大部分od都经历过。最近辞职回老家,和老爸散步每次他都会感慨街上的蔬菜小贩多不容易,他们晚上就窝在那种三轮小货车的驾驶室里,腿都伸不直,我们这里晚上零下了,只盖一条薄毛毯,始终舍不得住我们镇上几十块的酒店,因为一车蔬菜就赚几百块顶多一千而且要卖好久,这样的例子还有太多了。这种芸芸众生可能辛苦了一天之后,打开手机看到网上的凡尔赛发言,跟风喷了几句发泄情绪,我觉得这种人不应该扣上“躺平”的帽子。我觉得大部分正常人都是努力的,或者曾经努力过,但世界上有太多努力解决不了的无奈了,甚至说你都没有那个努力的机会,不过正因如此,才显得坚持不懈的努力奋斗之人的难得可贵,认清生活的真相后仍然热爱生活,敢于直面现实的淋漓。
段段STEADY觉醒与突...
点赞 评论 收藏
分享
评论
1
7
分享

创作者周榜

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