练习 - 使用维数组和函数查找密码

Exercise - find a passcode using dimensional arrays and function

我坚持这个:

编写一个名为 getValidPassword 的函数,将二维数组作为参数。

第一个数组中的每个条目代表一个密码。您需要从您的函数中找到没有奇数位的密码和 returns 该密码。 这是一个例子:

var loggedPasscodes =[
[1, 4, 4, 1],
[1, 2, 3, 1],
[2, 6, 0, 8],
[5, 5, 5, 5],
[4, 3, 4, 3]
];
getValidPassword(loggedPasscodes) // returns the array: [2, 6, 0, 8]

尝试过这种方式,但错误消息显示:>>>>代码不正确函数 getValidPassword 未按要求工作。" [2,6,0,8].

`var loggedPasscodes=[
    [1, 4, 4, 1],
[1, 2, 3, 1],
[2, 6, 0, 8],
[5, 5, 5, 5],
[4, 3, 4, 3],
];
var getValidPassword = function(getPassword){
var passcode = [];
var cache = [];
for (var i = 0; i < getPassword.length; i++){
for (var j = 0; j < getPassword[i].length; j++){
if(getPassword[i][j] % 2 === 0){           cache.push(getPassword[i][j]);
}
else {break;
}
if(getPassword[i].length === cache.length){
passcode= cache.slice();
}
}
}
return passcode;
};
console.log('[' + getValidPassword(loggedPasscodes) + ('') + ']');`

还有这个:

function getValidPassword(loggedPasscodes) {
    return loggedPasscodes.filter(passcode => passcode.every(n => n % 2 === 0));
};

let loggedPasscodes =[
    [1, 4, 4, 1],
    [1, 2, 3, 1],
    [2, 6, 0, 8],
    [5, 5, 5, 5],
    [10, 2, 4, 42],
    [4, 3, 4, 3]
];

console.log(getValidPassword(loggedPasscodes));
and


function getValidPassword(loggedPasscodes) {
    for (let i = 0; loggedPasscodes.length > i; i++) {
        let passcode = loggedPasscodes[i];
        let temImpar = false;
        for (let j = 0; passcode.length > j; j++) {
            if (passcode[j] % 2 !== 0)  { // ímpar
                temImpar = true;
                 números)
                break;
            }
        }
        if (! temImpar) {
            return passcode; 
    }
};



 let loggedPasscodes =[
        [1, 4, 4, 1],
        [1, 2, 3, 1],
        [2, 6, 0, 8],
        [5, 5, 5, 5],
        [4, 3, 4, 3]
    ];
    
    console.log(getValidPassword(loggedPasscodes)); // [2, 6, 0, 8

]

还有这个:

function getValidPassword(loggedPasscodes) {
let codes = [];
for (let i = 0; loggedPasscodes.length > i; i++) {
    let passcode = loggedPasscodes[i];
    let temImpar = false;
    for (let j = 0; passcode.length > j; j++) {
        if (passcode[j] % 2 !== 0)  { // ímpar
            temImpar = true;
           
            break;
        }
    }
    if (! temImpar) {
        codes.push(passcode); 
    }
}
return codes;
};

let loggedPasscodes =[
    [1, 4, 4, 1],
    [1, 2, 3, 1],
    [2, 6, 0, 8],
    [5, 5, 5, 5],
    [4, 3, 4, 3]
];

console.log(getValidPassword(loggedPasscodes))

这个:

function getValidPassword(loggedPasscodes) {
    return loggedPasscodes.find(passcode => passcode.every(n => n % 2 === 0));
};

let loggedPasscodes =[
    [1, 4, 4, 1],
    [1, 2, 3, 1],
    [2, 6, 0, 8],
    [5, 5, 5, 5],
    [4, 3, 4, 3]
];

console.log(getValidPassword(loggedPasscodes)); // [2, 6, 0, 8]

也试着复制类似这个例子的东西:

function retornaNNumerosPares(n) {
let numerosPares = [];
for (let i = 0; numerosPares.length < n; i++) {
    if (i % 2 == 0) {
        numerosPares.push(i);
    }
}
return numerosPares;

}

console.log(retornaNNumerosPares(5));

但是上面的 none 是有效的。你能帮帮我吗,我几乎完成了所有练习。

你能帮忙吗?

我首先检查每个数组的第一个值,以剔除无趣的值。任何匹配都会执行我的第二个循环,并且在任何检测到它甚至会取消。

如果完全匹配,您将 return 评论中显示的结果或推送它并继续查找更多代码。

let loggedPasscodes = [
  [1, 4, 4, 1],
  [1, 2, 3, 1],
  [2, 6, 0, 8],
  [5, 5, 5, 5],
  [4, 3, 4, 3]
];

function getValidPassword(loggedPasscodes) {
  let Codes = [];
  for (let i = 0; i < loggedPasscodes.length; i++) {
    console.log("Read Array:", i);
    if (loggedPasscodes[i][0] % 2 == 0) { // Check if first value is even
      let GoodCode = true;
      for (let x = 1; x < 4; x++) { // Let's fast check the array now
        if (loggedPasscodes[i][x] % 2 != 0) {
          GoodCode = false;
          break; // Break if it's a waste of time (odds)
        }
      }
      //if (GoodCode == true) Codes.push(loggedPasscodes[i]); // Build our array if there's more codes even.
      if (GoodCode == true) return loggedPasscodes[i];
    }
  }
  return Codes;
};
console.log(getValidPassword(loggedPasscodes)); // [2, 6, 0, 8]

快速方法抓住一切机会结束不必要的循环。

此方法迭代代码数组并通过检查不需要的数字来迭代代码,然后执行外循环的继续,否则 return 在内循环结束时找到的数组。

const
    getValidPassword = codes => {
        outer: for (const code of codes) {
            for (const value of code) if (value % 2) continue outer;
            return code;
        }
    },
    loggedPasscodes = [[1, 4, 4, 1], [1, 2, 3, 1], [2, 6, 0, 8], [5, 5, 5, 5], [4, 3, 4, 3]];

console.log(getValidPassword(loggedPasscodes));