[JS] 로그인 성공? programmers new Map 객체

0

코딩테스트

목록 보기
75/80
post-thumbnail

🎀 문제

머쓱이는 프로그래머스에 로그인하려고 합니다. 머쓱이가 입력한 아이디와 패스워드가 담긴 배열 id_pw와 회원들의 정보가 담긴 2차원 배열 db가 주어질 때, 다음과 같이 로그인 성공, 실패에 따른 메시지를 return하도록 solution 함수를 완성해주세요.

  • 아이디와 비밀번호가 모두 일치하는 회원정보가 있으면 "login"을 return합니다.
  • 로그인이 실패했을 때 아이디가 일치하는 회원이 없다면 “fail”를, 아이디는 일치하지만 비밀번호가 일치하는 회원이 없다면 “wrong pw”를 return 합니다.
function solution(id_pw, db) {
    var answer = '';
    return answer;
}

🎀 내 답변

function solution(id_pw, db) {
    let result = "";
    db.map((item) => {
        if (item[0] === id_pw[0] && item[1] === id_pw[1]) result = "login";
        else if (item[0] === id_pw[0] && item[1] !== id_pw[1]) result = "wrong pw";
        else if (item[0] !== id_pw[0] && item[1] !== id_pw[1]) result = "fail";
    });
    return result;
}

solution(
    ["meosseugi", "1234"],
    [
        ["rardss", "123"],
        ["yyoom", "1234"],
        ["meosseugi", "1234"],
    ]
);

for문 말고 map()을 활용해서 풀어보았다.
하지만 더 간결하게 줄여보고 싶어...!!!

🎀 더 나은 답변

function solution(id_pw, db) {
    const [id, pw] = id_pw;
    const map = new Map(db);
    console.log(map);
    console.log(map.has(id));
    console.log(map.get(id));
    return map.has(id) ? (map.get(id) === pw ? "login" : "wrong pw") : "fail";
}

코드를 하나씩 뜯어보자.

  1. 구조 분해 할당을 사용해서 id_pw 배열에 담긴 각각의 값에 id, pw라는 변수를 지정한다.

    const [id, pw] = id_pw;
    
    // 아래와 같이 변수가 지정되어 진다.
    id = "meosseugi"
    pw = "1234"
  2. Map 객체를 생성해 준다.

    const map = new Map(db);
    console.log(map);

    db에 들어온 배열을 가지고 Map 객체를 생성해 준다.
    그리고 console에 찍어보면 아래와 같이 나오게 된다.

    객체마냥 keyvalue 값으로 분해되어 진 것이 보인다.

  3. 그럼 이제 삼항 연산자를 이용해서 코드 작성해 보자.

    return map.has(id) ? (map.get(id) === pw ? "login" : "wrong pw") : "fail";
  • id = "meosseugi"와 동일한 key 값이 있는지 확인한다.
  • 있다면?
    • map.get으로 해당 keyvalue 값("1234")을 가져와서 pw = "1234"와 비교한다.
    • 같다면? "login" 출력
    • 다르다면? "wrong pw" 출력
  • 없다면 fail을 바로 출력





Map 객체를 숙지하고 잘 다룰 수 있는 날이 오겠찌?

profile
일단 해. 그리고 잘 되면 잘 된 거, 잘 못되면 그냥 해본 거!

0개의 댓글