2018-10-19 12:48:28 +00:00
|
|
|
|
# -*- coding: latin-1 -*-
|
2019-07-16 23:09:53 +00:00
|
|
|
|
"""
|
2018-10-19 12:48:28 +00:00
|
|
|
|
Name scores
|
|
|
|
|
Problem 22
|
|
|
|
|
|
2019-07-16 23:09:53 +00:00
|
|
|
|
Using names.txt (right click and 'Save Link/Target As...'), a 46K text file
|
|
|
|
|
containing over five-thousand first names, begin by sorting it into
|
|
|
|
|
alphabetical order. Then working out the alphabetical value for each name,
|
|
|
|
|
multiply this value by its alphabetical position in the list to obtain a name
|
|
|
|
|
score.
|
2018-10-19 12:48:28 +00:00
|
|
|
|
|
2019-07-16 23:09:53 +00:00
|
|
|
|
For example, when the list is sorted into alphabetical order, COLIN, which is
|
|
|
|
|
worth 3 + 15 + 12 + 9 + 14 = 53, is the 938th name in the list. So, COLIN would
|
|
|
|
|
obtain a score of 938 × 53 = 49714.
|
2018-10-19 12:48:28 +00:00
|
|
|
|
|
|
|
|
|
What is the total of all the name scores in the file?
|
2019-07-16 23:09:53 +00:00
|
|
|
|
"""
|
|
|
|
|
import os
|
|
|
|
|
|
|
|
|
|
|
2018-10-19 12:48:28 +00:00
|
|
|
|
try:
|
2019-07-16 23:09:53 +00:00
|
|
|
|
xrange # Python 2
|
2018-10-19 12:48:28 +00:00
|
|
|
|
except NameError:
|
2019-07-16 23:09:53 +00:00
|
|
|
|
xrange = range # Python 3
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def solution():
|
|
|
|
|
"""Returns the total of all the name scores in the file.
|
|
|
|
|
|
|
|
|
|
>>> solution()
|
|
|
|
|
871198282
|
|
|
|
|
"""
|
|
|
|
|
with open(os.path.dirname(__file__) + "/p022_names.txt") as file:
|
|
|
|
|
names = str(file.readlines()[0])
|
|
|
|
|
names = names.replace('"', "").split(",")
|
2018-10-19 12:48:28 +00:00
|
|
|
|
|
2019-07-16 23:09:53 +00:00
|
|
|
|
names.sort()
|
2018-10-19 12:48:28 +00:00
|
|
|
|
|
2019-07-16 23:09:53 +00:00
|
|
|
|
name_score = 0
|
|
|
|
|
total_score = 0
|
2018-10-19 12:48:28 +00:00
|
|
|
|
|
2019-07-16 23:09:53 +00:00
|
|
|
|
for i, name in enumerate(names):
|
|
|
|
|
for letter in name:
|
|
|
|
|
name_score += ord(letter) - 64
|
2018-10-19 12:48:28 +00:00
|
|
|
|
|
2019-07-16 23:09:53 +00:00
|
|
|
|
total_score += (i + 1) * name_score
|
|
|
|
|
name_score = 0
|
|
|
|
|
return total_score
|
2018-10-19 12:48:28 +00:00
|
|
|
|
|
|
|
|
|
|
2019-07-16 23:09:53 +00:00
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
print(solution())
|