該算法題來自于 codewars【語言: javascript】缆镣,翻譯如有誤差有额,敬請諒解~
- 任務(wù)
- 我的朋友想要起一個樂隊名。她喜歡使用以下公式命名樂隊:
'The' +
首字母大寫的單詞dolphin -> The Dolphin
- 然而值漫,當(dāng)一個單詞的第一個和最后一個字母相同時乡数,她喜歡重復(fù)該單詞兩次,并將它們與第一個和最后一個字母連接在一起嗅战,然后合并成一個如下所示的單詞(前面沒有
“The”
)
alaska -> Alaskalaska europe -> Europeurope
- 請編寫一個函數(shù)妄田,接收一個參數(shù)(字符串)俺亮,返回一個符合上述要求的樂隊名稱。
- 解答
- 其一
const bandNameGenerator = str => {
const subStr = str.slice(1,str.length);
return str.charAt(str.length - 1) == str.charAt(0) ? str.charAt(0).toUpperCase() + subStr.repeat(2) : 'The ' + str.charAt(0).toUpperCase() + subStr;
}
- 其二
const bandNameGenerator = s => s[0] != s[s.length-1] ? "The " + s[0].toUpperCase() + s.slice(1) : s[0].toUpperCase() + s.slice(1) + s.slice(1);
- 其三
const startEndSame = (str = '') => str[0] === str[str.length - 1];
const repeat = (str) => `${ str.slice(0, -1) }${ str }`;
const capitalize = (str) => `${ str[0].toUpperCase() }${ str.slice(1) }`;
const bandNameGenerator = (str) => startEndSame(str) ? capitalize(repeat(str)) : `The ${ capitalize(str) }`;
- 其四
function bandNameGenerator(s) {
return /^(.).*\1$/.test(s)?s[0].toUpperCase()+s.slice(1)+s.slice(1):"The "+s[0].toUpperCase()+s.slice(1)
}