freecodecamp算法思路记录

  • Check for Palindromes

检查回文字符串如果给定的字符串是回文,返回true,反之,返回false。如果一个字符串忽略标点符号、大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文)。注意你需要去掉字符串多余的标点符号和空格,然后把字符串转化成小写来验证此字符串是否为回文。函数参数的值可以为"racecar","RaceCar"和"race CAR"。

function palindrome(str) { 
        // 请把你的代码写在这里
 return true;}
palindrome("eye");

思考路线如下:
字符串变成数组、改大小写(不难)str.split().str.toLowerCase()

去除标点符号,空格(走弯路)打算参考Record Collection

// 初始化变量var collection = { 2548: { album: "Slippery When Wet", artist: "Bon Jovi", tracks: [ "Let It Rock", "You Give Love a Bad Name" ] }, 2468: { album: "1999", artist: "Prince", tracks: [ "1999", "Little Red Corvette" ] }, 1245: { artist: "Robert Palmer", tracks: [ ] }, 5439: { album: "ABBA Gold" }};// 请只修改这条注释以下的代码function update(id, prop, value) { if ( value !=='' && prop !== 'tracks' ){collectionCopy[id][prop]=value;} if ( value !=='' && prop == 'tracks' ){collectionCopy[id][prop].push(value);} if ( value ==='' ) {delete collectionCopy[id][prop];} return collection;}// 你可以修改这一行来测试你的代码update(5439, "artist", "ABBA");

不,事实上是我想的太复杂了,应该直接使用参考
对比字符(难点)使用for嵌套if语句下面的错误,调用两个for出来的结果不对.

var xuShu=jianYan.length-1;for (var h=0;hxuShu/2;k--) { if (jianYan[i] == jianYan[k]) {return true;} } if (jianYan[i] !== jianYan[k]) {return false;}}

目前的新思路是,将数组分两半,后者reverse再进行对比,不知道可行否。

  • Title Case a Sentence

function titleCase(str) {
  var arry=str.split(" ");
  var long=arry.length;
/*
  var test=arry.shift().toLowerCase().split("");
  var c=test.shift();//首字母
  c=c.toUpperCase();
  test.unshift(c);
  var d=test.join("");
  arry.push(d);
*/  
  
  for (var i=0;i
  • Return Largest Numbers in Arrays

function largestOfFour(arr) {
  var long=arr.length;
  for (i=0;i
  • Falsy Bouncer

过滤数组假值(真假美猴王)
删除数组中的所有假值。
在JavaScript中,假值有false、null、0、""、undefined和NaN。
当你完成不了挑战的时候,记得开大招'Read-Search-Ask'。
这是一些对你有帮助的资源:
Boolean Objects
Array.filter()

第一次失败代码

function bouncer(arr) {
  var test=[false,null,0,"",undefined,NaN];
  var result=[];
  
  for (var i=0;i

因为null值为0没有考虑到。

你可能感兴趣的:(freecodecamp算法思路记录)