Reverse a String 翻轉(zhuǎn)字符串
先把字符串轉(zhuǎn)化成數(shù)組甩恼,再借助數(shù)組的reverse方法翻轉(zhuǎn)數(shù)組順序措嵌,最后把數(shù)組轉(zhuǎn)化成字符串黔衡。
function reverseString(str) {
var arr1 = str.split("");
str = (arr1.reverse()).join("");
return str;
}
reverseString("hello"); //olleh
相關(guān)知識:
Factorialize a Number 計算一個整數(shù)的階乘
function factorialize(num) {
if(num === 0){
num = 1;
return num;
} else {
for (var i = num - 1; i > 0; i--) {
num = num * i;
}
}
return num;
}
factorialize(5); //120
相關(guān)知識:
Check for Palindromes 回文判定
如果給定的字符串是回文赁严,返回true胜嗓,反之邑跪,返回false次坡。
function palindrome(str) {
var result;
var arr = (str.split("")).reverse();
var str2 = arr.join("");
str = str.toLowerCase().replace(/\W/g,"").replace("_","");
str2 = str2.toLowerCase().replace(/\W/g,"").replace("_","");
result = str === str2;
return result;
}
palindrome("race car"); //true
相關(guān)知識:
Find the Longest Word in a String 找出最長的字符串
找到提供的句子中最長的單詞呼猪,并計算它的長度,函數(shù)的返回值應(yīng)該是一個數(shù)字砸琅。
function findLongestWord(str) {
var str1 = str.split(" ");
var str2 = str1.sort(function(a,b){
return b.length - a.length;
});
var result = str2[0].length;
return result;
}
findLongestWord("The quick brown fox jumped over the lazy dog"); //6
相關(guān)知識:
Title Case a Sentence 單詞首字母大寫
確保字符串的每個單詞首字母都大寫宋距,其余部分小寫,像’the’和’of’這樣的連接符同理。
function titleCase(str) {
var str1 = str.split("");
for (i = 0; i < str1.length; i++) {
if (i === 0) {
str1[i] = str1[i].toUpperCase();
} else if (str1[i - 1] === " ") {
str1[i] = str1[i].toUpperCase();
} else {
str1[i] = str1[i].toLowerCase();
}
}
return str1.join("");
}
titleCase("I'm a little tea pot"); //"I'm A Little Tea Pot"
相關(guān)知識:
Return Largest Numbers in Arrays 找出最大值
大數(shù)組中包含了4個小數(shù)組症脂,分別找到每個小數(shù)組中的最大值谚赎,然后把它們串聯(lián)起來,形成一個新數(shù)組诱篷。
function largestOfFour(arr) {
var newArr = [];
for( var i = 0; i < arr.length; i++) {
var arr1 = arr[i].sort(function(a,b){
return b - a;
});
newArr.push(arr1[0]);
}
return newArr;
}
largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]]); //[5,27,39,1001]
相關(guān)知識:
Confirm the Ending 文尾識別
檢查一個字符串(str)是否以指定的字符串(target)結(jié)尾壶唤。
如果是,返回true;如果不是棕所,返回false闸盔。
function confirmEnding(str, target) {
var n = target.length;
var string = str.substr(-n);
return string === target;
}
confirmEnding("Bastian", "n"); //true
相關(guān)知識:
Repeat a string repeat a string 重復(fù)一句話
重復(fù)一個指定的字符串 num次,如果num是一個負數(shù)則返回一個空字符串
function repeat(str, num) {
if (num < 0) {
str = "";
} else {
var i = 1;
var str1 = "";
while( i < num) {
i += 1;
str1 += str;
}
str += str1;
}
return str;
}
repeat("abc", 3); //"abcabcabc"
相關(guān)知識:
Truncate a string 截斷一句話
如果字符串的長度比指定的參數(shù)num長琳省,則把多余的部分用…來表示迎吵。
切記,插入到字符串尾部的三個點號也會計入字符串的長度针贬。
但是击费,如果指定的參數(shù)num小于或等于3,則添加的三個點號不會計入字符串的長度桦他。
function truncate(str, num) {
if(num >= str.length){
return str;
}
var newStr = "";
if(num <= 3) {
newStr = str.slice(0,num);
} else {
newStr = str.slice(0,num-3);
}
newStr += "...";
return newStr;
}
truncate("A-tisket a-tasket A green and yellow basket", "A-tisket a-tasket A green and yellow basket".length + 2); //A-tisket a-tasket A green and yellow basket
相關(guān)知識:
Chunky Monkey 分割數(shù)組
把一個數(shù)組arr按照指定的數(shù)組大小size分割成若干個數(shù)組塊蔫巩。
例如:
chunk([1,2,3,4],2)=[[1,2],[3,4]];
chunk([1,2,3,4,5],2)=[[1,2],[3,4],[5]];
function chunk(arr, size) {
var resultArr = [];
for(var i = 0; i <= arr.length-size; i += size){
resultArr.push(arr.slice(i,i+size));
}
var num = arr.length%size;
var lastArr = arr.slice(arr.length-num);
if(num === 0) {
return resultArr;
} else {
resultArr.push(lastArr);
return resultArr;
}
}
chunk([0, 1, 2, 3, 4, 5], 4); //[[0, 1, 2, 3], [4, 5]]
相關(guān)知識:
Slasher Flick 截斷數(shù)組
返回一個數(shù)組被截斷n個元素后還剩余的元素,截斷從索引0開始快压。
function slasher(arr, howMany) {
var result = arr.splice(howMany,arr.length);
return result;
}
slasher([1, 2, 3], 0); //[1, 2, 3]
相關(guān)知識:
Mutations 字母是否相同
如果數(shù)組第一個字符串元素包含了第二個字符串元素的所有字符批幌,函數(shù)返回true。
function mutation(arr) {
var result = true;
for (var i = 0; i < arr.length; i++){
arr[i] = arr[i].toLowerCase();
}
for (var j = 0; j < arr[1].length; j++) {
var num = arr[0].indexOf(arr[1][j]);
if(num == -1){
result = false;
return result;
}
}
return result;
}
mutation(["Mary", "Aarmy"]); //true
相關(guān)知識:
Falsy Bouncer 刪掉假值
刪除數(shù)組中的所有假值嗓节。
刪除數(shù)組中的所有假值荧缘。
function bouncer(arr) {
var result = arr.filter(function(element){
return !!element;
});
return result;
}
bouncer([7, "ate", "", false, 9]); //[7, "ate", 9]
相關(guān)知識:
Seek and Destroy 摧毀數(shù)組中的一些值
實現(xiàn)一個摧毀(destroyer)函數(shù),第一個參數(shù)是待摧毀的數(shù)組拦宣,其余的參數(shù)是待摧毀的值截粗。
function destroyer(arr) {
var arr1 = [];
for(var i = 1; i < arguments.length; i++){
arr1.push(arguments[i]);
}
var result = arr.filter(function(element){
return (arr1.indexOf(element) < 0);
});
return result;
}
destroyer([1, 2, 3, 1, 2, 3], 2, 3); //[1, 1]
相關(guān)知識:
Where do I belong 找出新元素在數(shù)組中的位置
先給數(shù)組排序,然后找到指定的值在數(shù)組的位置鸵隧,最后返回位置對應(yīng)的索引绸罗。
例子:
where([1,2,3,4], 1.5) 應(yīng)該返回 1。因為1.5插入到數(shù)組[1,2,3,4]后變成[1,1.5,2,3,4]豆瘫,而1.5對應(yīng)的索引值就是1珊蟀。
where([20,3,5], 19) 應(yīng)該返回 2。因為數(shù)組會先排序為 [3,5,20],19插入到數(shù)組[3,5,20]后變成[3,5,19,20]育灸,而19對應(yīng)的索引值就是2腻窒。
function where(arr, num) {
arr.push(num);
arr.sort(function(a,b){
return a-b;
});
return arr.indexOf(num);
}
where([40, 60], 50); //1
相關(guān)知識:
Caesars Cipher 移位密碼
移位密碼也就是密碼中的字母會按照指定的數(shù)量來做移位。
一個常見的案例就是ROT13密碼磅崭,字母會移位13個位置儿子。由’A’ ? ‘N’, ‘B’ ? ‘O’,以此類推砸喻。
寫一個ROT13函數(shù)具篇,實現(xiàn)輸入加密字符串吃挑,輸出解密字符串号胚。
function rot13(str) { // LBH QVQ VG!
var arr = [];
for(var i = 0; i < str.length; i++){
var code = str.charCodeAt(i);
if(code > 77) {
arr.push(code-13);
} else if(code > 64) {
arr.push(code+13);
} else {
arr.push(code);
}
}
var arr1 = [];
for(var j = 0; j < arr.length; j++){
arr1.push(String.fromCharCode(arr[j]));
}
return arr1.join("");
}
rot13("SERR PBQR PNZC"); //"FREE CODE CAMP"
相關(guān)知識: