Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Resolve Project Euler 22 #1224

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 36 additions & 0 deletions Project-Euler/Problem022.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
import * as fs from 'fs'
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why not just import readFileSync from fs? It seems to be the only function you need.


/**
* Problem 22 - Names scores
* @see {@link https://projecteuler.net/problem=22}
*
* 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.
*
* 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.
*
* What is the total of all the name scores in the file?
*/

export function namesScores (txtPath) {
const names = fs.readFileSync(txtPath, 'utf8').replaceAll('"', '').split(',')

// Sort ascending the list of names
names.sort((a, b) => (a > b))

let totalSum = 0
for (let i = 0; i < names.length; i++) {
let nameSum = 0
for (let j = names[i].length; j--;) {
nameSum += names[i].charCodeAt(j) - ('a'.charCodeAt(0) - 1)
}

totalSum += nameSum * (i + 1)
}

return totalSum
}
9 changes: 9 additions & 0 deletions Project-Euler/test/Problem022.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import * as path from 'path'
import { namesScores } from '../Problem022.js'

describe('checking Names Scores', () => {
// Project Euler Names Scores
test('Test Names Scores', () => {
expect(namesScores(path.resolve('./Project-Euler/test/Problem022.txt'))).toBe(871198282)
})
})
1 change: 1 addition & 0 deletions Project-Euler/test/Problem022.txt

Large diffs are not rendered by default.