# -*- coding:utf-8 -*-
'''
Created on 2013-3-29
@author: naughty
'''
dict={}
dict['A']=1
dict['B']=2
dict['C']=3
dict['D']=4
dict['E']=5
dict['F']=6
dict['G']=7
dict['H']=8
dict['I']=9
dict['J']=10
dict['K']=11
dict['L']=12
dict['M']=13
dict['N']=14
# .....其他字母
def count_(s):
p=len(s)-1
count=0
for x in xrange(len(s)):
count+=get(x)*dict[s[p-x]]
return count
def get(p):
return 26**p
print count_('AC')
题目是这样的:
假设A=1,B=2,C=3...AA=27,AB=28...AAA=xxx(表示某个数字),写一个函数统计一个字符串的值是多少
在上面的代码中,利用的字典来映射每个字母的含义。当然也可以每次计算每个字母代表的数字。但是会有效率问题。

本文介绍了一个用于计算字符串中每个字母对应数值总和的函数。通过建立字母与数值间的映射关系,该函数能够高效地计算出如AC这类字符串的具体数值。

971

被折叠的 条评论
为什么被折叠?



