牛客网python算法练习(二)电话号码分身

坚持一周五题
继MIUI8推出手机分身功能之后,MIUI9计划推出一个电话号码分身的功能:首先将电话号码中的每个数字加上8取个位,然后使用对应的大写字母代替("ZERO", "ONE", "TWO", "THREE","FOUR", "FIVE", "SIX", "SEVEN","EIGHT", "NINE"), 然后随机打乱这些字母,所生成的字符串即为电话号码对应的分身。

输入描述:

第一行是一个整数T(1 ≤ T ≤ 100)表示测试样例数;接下来T行,每行给定一个分身后的电话号码的分身(长度在3到10000之间)。

输出描述:

输出T行,分别对应输入中每行字符串对应的分身前的最小电话号码(允许前导0)。
示例1

输入

4
EIGHT
ZEROTWOONE
OHWETENRTEO
OHEWTIEGTHENRTEO

输出

0
234
345
0345

解题思路主要是看字母出现的个数,比如EIGHT中的G在所有数字中只会出现一次

我的python代码如下,虽然没有优化内存,但也能通过case

#coding=utf-8
'''

继MIUI8推出手机分身功能之后,MIUI9计划推出一个电话号码分身的功能:首先将电话号码中的每个数字加上8取个位,然后使用对应的大写字母代替 ("ZERO", "ONE", "TWO", "THREE", "FOUR", "FIVE", "SIX", "SEVEN", "EIGHT", "NINE"), 然后随机打乱这些字母,所生成的字符串即为电话号码对应的分身。
输入描述:
第一行是一个整数T(1 ≤ T ≤ 100)表示测试样例数;接下来T行,每行给定一个分身后的电话号码的分身(长度在3到10000之间)。
输出描述:
输出T行,分别对应输入中每行字符串对应的分身前的最小电话号码(允许前导0)。
示例1
输入

4
EIGHT
ZEROTWOONE
OHWETENRTEO
OHEWTIEGTHENRTEO

输出

0
234
345
0345


'''

# zi = ["ZERO", "ONE", "TWO", "THREE", "FOUR", "FIVE", "SIX", "SEVEN", "EIGHT", "NINE"]
def exit(s):
        a = [0]*10
    ####发现ZERO
        a[2] = s.count('Z')
    ####发现TWO
        a[4] = s.count('W')
    ####发现FOUR
        a[6] = s.count('U')
    ####发现SiX
        a[8] = s.count('X')
    ####发现eight
        a[0] = s.count('G')

    ####发现sSEVEN,s的次数减去six
        a[9] = s.count('S') - a[8]
    ########发现three,由于H只在 THREE和EIGHT中出现,所以计算THREE可以用H出现的次数减去G出现的次数
        a[5] = s.count('H') - a[0]
    ###发现ONE,由于O在zero、one、two、four中出现,所以可以通过计算o出现的次数减去zero、two、four
        a[3] = s.count('O') - a[2] - a[4] - a[6]
    ####发现Five,由于F只出现两次,计算F出现的次数减去Four
        a[7] = s.count('F') - a[6]
    ####发现Nine,I出现四次,计算I出现的次数减去FIVE,SIX、EIGHT
        a[1] = s.count('I') - a[7] - a[8] - a[0]
        s = ''
        for i in range(10):
            s += str(i)*a[i]
        return s
n = int(input())
for i in range(n):
    a_line.append(str(raw_input()))

for i in range(n):
    print exit(a_line[i])

看了一下官网的答案,总体思路差不多,但是减少了一些变量和计算,运行时间缩减一半,参考代码如下

num=int(raw_input())
n=[0]*10
for i in range(num):
    instr=raw_input()
#统计各位数字次数
    n[0]=instr.count('Z')
    n[2]=instr.count('W')
    n[4]=instr.count('U')
    n[6]=instr.count('X')
    n[8]=instr.count('G')
    n[1]=instr.count('O')-n[0]-n[2]-n[4]
    n[3]=instr.count('T')-n[2]-n[8]
    n[5]=instr.count('F')-n[4]
    n[7]=instr.count('S')-n[6]
    n[9]=instr.count('I')-n[5]-n[6]-n[8]
#对应数字位-8
    m=n[8:]+n[0:8]
    s=''
    for i in range(len(m)):
        s += str(i)*m[i]
    print s


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值