Merge pull request #15856 from AungMyoKyaw/feat/eluer-prob-4

feat(euler-problem): Add tests and solution for Problem 4: Largest palindrome product
pull/18182/head
Berkeley Martinez 2018-01-16 08:13:31 -08:00 committed by GitHub
commit 65a37c32dc
2 changed files with 13 additions and 8 deletions

View File

@ -94,17 +94,20 @@
"type": "bonfire",
"title": "Problem 4: Largest palindrome product",
"tests": [
"assert.strictEqual(euler4(), 906609, 'message: <code>euler4()</code> should return 906609.');"
"assert.strictEqual(largestPalindromeProduct(2), 9009, 'message: <code>largestPalindromeProduct(2)</code> should return 9009.');",
"assert.strictEqual(largestPalindromeProduct(3), 906609, 'message: <code>largestPalindromeProduct(3)</code> should return 906609.');"
],
"solutions": [
"const largestPalindromeProduct = (digit)=>{\n let start = 1;\n let end = Number(`1e${digit}`) - 1;\n let palindrome = [];\n for(let i=start;i<=end;i++){\n for(let j=start;j<=end;j++){\n let product = i*j;\n let palindromeRegex = /\\b(\\d)(\\d?)(\\d?).?\\3\\2\\1\\b/gi;\n palindromeRegex.test(product) && palindrome.push(product);\n }\n }\n return Math.max(...palindrome);\n}"
],
"solutions": [],
"translations": {},
"challengeSeed": [
"function euler4() {",
"function largestPalindromeProduct(digit) {",
" // Good luck!",
" return true;",
"}",
"",
"euler4();"
"largestPalindromeProduct(3);"
],
"description": [
"A palindromic number reads the same both ways. The largest palindrome made from the product of two 2-digit numbers is 9009 = 91 × 99.",

View File

@ -215,10 +215,12 @@ Observable.from(getChallenges())
.toArray()
.subscribe(
(noSolutions) => {
if(noSolutions){
console.log(
'# These challenges have no solutions\n- [ ] ' +
noSolutions.join('\n- [ ] ')
);
}
},
err => { throw err; },
() => process.exit(0)