Jump to content

Extrair password de um array corrompido


Recommended Posts

Olá tenho um exercício para resolver que me ocupa a cabeça há já vários dias...

Já fiz e refiz , também já li que se poderiam usar métodos regex mas não se aplica aqui, neste exercício , dado que ainda não foram abordados nesta plataforma.

Vou deixar aqui o exercício, bem como a minha tentativa , na esperança que alguém me possa direccionar no caminho do que me está a falhar, sinto que estou perto mas alguma coisa falha...

// exercício:

Citação

 

Create a function named extractPassword which takes an array of characters (which includes some trash characters) and returns a string with only valid characters (a - z, A - Z, 0 - 9).

 

Here's an example:

 

extractPassword(['a', '-', '~', '1', 'a', '/']); // should return the string 'a1a'

extractPassword(['~', 'A', '7', '/', 'C']); // should return the string 'A7C'

 

 

// o meu código:

var password = (['a', 'º', '~', 'z', 'A', '&', 'Z', '0', '*', '9']);
var newPass =[];
var arrayLength = password.length;

function extractPassword(password) {
    for (var i = 0; i < arrayLength; i ++) {
        var j = password[i];
        
        if(('a'<= j && j<= 'z') || ('A'<=j && j<='Z') || ('0'<=j && j<='9')) {
            newPass.push(j);
        }
        
        
    } return newPass;
    
   
}
extractPassword(password);  
console.log(' '+ newPass);

// output:

 

>>>>Code is incorrect

Your function is not returning the correct value

a,z,A,Z,0,9

Link to post
Share on other sites
tiago.f

Olá.

 

Se o exercício pede para definires uma função, então provavelmente o teste que o teu prof desenvolveu vai chamar essa função e não vai saber nada acerca das variáveis globais que estás a definir antes.

Sugiro que removas todas as variáveis globais e fiques apenas com variáveis locais (dentro da função).

Depois, deves retornar uma string e não o array newPass.

Algo assim (nao testei):

 

function extractPassword(password) {
    let newPass = [];
    for (var i = 0; i < password.length; i ++) {
        var j = password[i];
        
        if(('a'<= j && j<= 'z') || ('A'<=j && j<='Z') || ('0'<=j && j<='9')) {
            newPass.push(j);
        }
    }
  
    return newPass.join('');   
}

 

Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.