题解 | 手机键盘

手机键盘

https://www.nowcoder.com/practice/20082c12f1ec43b29cd27c805cd476cd

def solution(s):
    keys = "22233344455566677778889999"
    # 每个字母在键上的位置(第几次按键)
    press = [1, 2, 3, 1, 2, 3, 1, 2, 3, 1, 2, 3, 1, 2, 3,
             1, 2, 3, 4, 1, 2, 3, 1, 2, 3, 4]
    total = 0
    prev_key = ''
    for ch in s:
        idx = ord(ch) - ord('a')
        cur_key = keys[idx]
        total += press[idx]
        if cur_key == prev_key:
            total += 2
        prev_key = cur_key
    return total
while True:
    try:
        s = input()
        print(solution(s))
    except :
        break

全部评论

相关推荐

政委qqq:这道题在算法竞赛里唯一考的就是高精度,但是只能难住C++这类语言,Python直接a+b秒天秒地
点赞 评论 收藏
分享
二十岁的编程男神王大...:读博吧兄弟,你这绩点太好了,何必转码,另外哈哈哈真见到有括号标出来985的,这个不标注也知道吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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