Python challenge_2

python challenge 上的第二题:http://www.pythonchallenge.com/pc/def/ocr.html

这个基本上是比较好理解的,查看源代码,找寻出现次数比较少的字母。然后我就理解成找出出现次数最少的。

import re
f = open(r'D:\pythonchallenge_2.txt')
dict = {}
for line in f:
    line = line.strip()
    l = len(line)
    while l:
        x = line[l-1]
        if x in dict:
            dict[x] += 1
        else:
            dict[x] =1
        l -= 1
temp = 1000000
for key,value in dict.items():
    if value <temp:
        x = key
        temp = value
print x

这段代码的输出是a。然后就不知道了,又到了查攻略的时间。发现直接把字典里面的所有数据都输出出来,无非也就下面的这几个。

!:6079

#:6115

%:6104

$:6046

&:6043

):6186

(:6154

+:6066

*:6034

@:6157

[:6108

]:6152

_:6112

^:6030

a:1

e:1

i:1

l:1

q:1

u:1

t:1

y:1

{:6046

}:6105

有办法理解的就是那几个字母了。输进去,发现是错的,再次找攻略,知道了python中dictionary的key是无序的,并不是按照加入的顺序显示的,每个字母都只出现一次,所以,所需要的信息赢就是按照字符出现的顺序组成的字符串重新写了一份代码:

import re
f = open(r'D:\pythonchallenge_2.txt')
s = ''
for line in f:
    line = line.strip()
    for i in line:
        if i.isalpha():
            s += i
print s

直接就输出答案equality下一题的链接就是:

http://www.pythonchallenge.com/pc/def/equality.html

把别人写的代码和自己写的相比较完全惨不忍睹。但是可以安慰自己,对代码还不熟悉,好好练习就好了。链接里面的同学写的很好呀。。。

http://blog.csdn.net/kosl90/article/details/7240915


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值