⭐ Lv. 0 - 로그인 성공?
머쓱이는 프로그래머스에 로그인하려고 합니다. 머쓱이가 입력한 아이디와 패스워드가 담긴 배열 id_pw
와 회원들의 정보가 담긴 2차원 배열 db
가 주어질 때, 다음과 같이 로그인 성공, 실패에 따른 메시지를 return하도록 solution 함수를 완성해주세요.
아이디와 비밀번호가 모두 일치하는 회원정보가 있으면 "login"을 return합니다.
로그인이 실패했을 때 아이디가 일치하는 회원이 없다면 “fail”를, 아이디는 일치하지만 비밀번호가 일치하는 회원이 없다면 “wrong pw”를 return 합니다.
id_pw
의 길이는 2입니다.id_pw
와 db
의 원소는 [아이디, 패스워드] 형태입니다.db
의 길이 ≤ 10db
의 원소의 길이는 2입니다.id_pw | db | result |
---|---|---|
["meosseugi", "1234"] | [["rardss", "123"], ["yyoom", "1234"], ["meosseugi", "1234"]] | "login" |
["programmer01", "15789"] | [["programmer02", "111111"], ["programmer00", "134"], ["programmer01", "1145"]] | "wrong pw" |
["rabbit04", "98761"] | [["jaja11", "98761"], ["krong0313", "29440"], ["rabbit00", "111333"]] | "fail" |
입출력 예 #1
입출력 예 #2
입출력 예 #3
첫 풀이는 단순 filter
를 이용하여 3가지의 case로 구분하여 조건문을 작성하여 다음과 같이 풀이하였다.
function solution(id_pw, db) {
if(db.filter((cur) => cur[0] === id_pw[0] && cur[1] === id_pw[1]).length) return "login";
else if(db.filter((cur) => cur[0] === id_pw[0]).length) return "wrong pw";
else return "fail";
}
하지만 이보다 Map
을 이용하여 풀이하면 더 쉽고 간단하게 풀이할 수 있을 것 같아, 다시 풀이하였다.
function solution(id_pw, db) {
const [id, pw] = id_pw;
let dbMap = new Map(db);
return dbMap.has(id) ? (dbMap.get(id) === pw ? "login" : "wrong pw") : "fail";
}
구조분해할당을 이용하여 id
, pw
에 아이디와 비밀번호 값을 저장하고, 2차원 배열을 Map 객체로 변환하여 method를 이용해 존재 여부를 파악하였다.