浅谈js中字符和数组一些基本算法题(2)

repeat("*", 3) 应该返回"***".
repeat("abc", 3) 应该返回"abcabcabc".
repeat("abc", 4) 应该返回"abcabcabcabc".
repeat("abc", 1) 应该返回"abc".
repeat("*", 8) 应该返回"********".
repeat("abc", -2) 应该返回"".

当你完成不了挑战的时候,记得开大招'Read-Search-Ask'。

这是一些对你有帮助的资源:

•Global String Object

function repeat(str, num) { // repeat after me var newstr = str; if(num >1){ for(var i = 1; i< num ; i ++){ str +=newstr; } return str; }else if(num == 1){ return str; }else{ return ""; } } repeat("abc", 3); repeat("*", 3);

6.Chunky Monkey

猴子吃香蕉可是掰成好几段来吃哦!

把一个数组arr按照指定的数组大小size分割成若干个数组块。

例如: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) { // Break it up. var arr1 = []; for (var i = 0; i < arr.length; i = i + size) { var arr2 = arr; arr1.push(arr2.slice(i, i + size)); } return arr1; } chunk(["a", "b", "c", "d"], 2);

7.Falsy Bouncer

真假美猴王!

删除数组中的所有假值。

在JavaScript中,假值有false、null、0、""、undefined 和NaN。

当你完成不了挑战的时候,记得开大招'Read-Search-Ask'。

这是一些对你有帮助的资源:

•Boolean Objects
•Array.filter()

例如:

bouncer([7, "ate", "", false, 9]) 应该返回 [7, "ate", 9].

bouncer(["a", "b", "c"])应该返回 ["a", "b", "c"].

bouncer([false, null, 0, NaN, undefined, ""]) 应该返回 [].

bouncer([1, null, NaN, 2, undefined]) 应该返回 [1, 2].

/* 这题注意是对filter的理解,这是我最开始的代码,写的不是很好,没多大参考价值 还要注意 NaN 比较。 自己不等于自己(NaN != NaN ) */ function bouncer(arr) { // Don't show a false ID to this bouncer. var arr1 =[]; var j = 0; arr.filter(function(val, index) { if (val === false || val === null || val === 0 || val === "" || val === undefined || val !== val) { arr1.push(index); } }); var len = arr1.length; for(var i = 0; i < len ; i++){ arr.splice(arr1[i]-j,1); j++; } return arr; } bouncer([7, "ate", "", false, 9]);

8.Seek and Destroy

金克斯的迫击炮!

实现一个摧毁(destroyer)函数,第一个参数是待摧毁的数组,其余的参数是待摧毁的值。

例如:

destroyer([1, 2, 3, 1, 2, 3], 2, 3) 应该返回 [1, 1].
destroyer([1, 2, 3, 5, 1, 2, 3], 2, 3) 应该返回 [1, 5, 1].
destroyer([3, 5, 1, 2, 2], 2, 3, 5) 应该返回 [1].
destroyer([2, 3, 2, 3], 2, 3) 应该返回 [].
destroyer(["tree", "hamburger", 53], "tree", 53) 应该返回["hamburger"].

这是一些对你有帮助的资源:

•Arguments object
•Array.filter()

function destroyer(arr) { // Remove all the values var tempArguments = arguments; return arr.filter(function(entry) { for(var i = 1; i< tempArguments.length; i++) { if (entry == tempArguments[i]) { return false; } } return true; }); } destroyer([1, 2, 3, 1, 2, 3], 2, 3);

9.Where do I belong

我身在何处?

先给数组排序,然后找到指定的值在数组的位置,最后返回位置对应的索引。

举例:where([1,2,3,4], 1.5) 应该返回1。因为1.5插入到数组[1,2,3,4]后变成[1,1.5,2,3,4],而1.5对应的索引值就是1。

同理,where([20,3,5], 19) 应该返回 2。因为数组会先排序为 [3,5,20],19插入到数组[3,5,20]后变成[3,5,19,20],而19对应的索引值就是2。

这是一些对你有帮助的资源:

•Array.sort()

function where(arr, num) { // Find my place in this sorted array. //注意sort() 排序规则 arr.sort(function(a,b){ return a- b; }); for(var i =0;i<arr.length;i++){ if(arr[i]>num | arr[i] == num){ return i; } } return arr.length; } where([5, 3, 20, 3], 5);

10.Caesars Cipher

让上帝的归上帝,凯撒的归凯撒。

下面我们来介绍风靡全球的凯撒密码Caesar cipher,又叫移位密码。

移位密码也就是密码中的字母会按照指定的数量来做移位。

一个常见的案例就是ROT13密码,字母会移位13个位置。由'A' ↔ 'N', 'B' ↔ 'O',以此类推。

写一个ROT13函数,实现输入加密字符串,输出解密字符串。

所有的字母都是大写,不要转化任何非字母形式的字符(例如:空格,标点符号),遇到这些特殊字符,跳过它们。

例如:

rot13("SERR PBQR PNZC") 应该解码为 "FREE CODE CAMP"

rot13("SERR CVMMN!") 应该解码为 "FREE PIZZA!"

rot13("SERR YBIR?") 应该解码为 "FREE LOVE?"

rot13("GUR DHVPX OEBJA QBT WHZCRQ BIRE GUR YNML SBK.") 应该解码为 "THE QUICK BROWN DOG JUMPED OVER THE LAZY FOX."

这是一些对你有帮助的资源:

•String.charCodeAt()
•String.fromCharCode()

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wzxwyw.html