[프로그래머스/Lv.0] 로그인 성공 ?

Lainlnya·2023년 2월 10일
0

프로그래머스

목록 보기
20/49
post-thumbnail

문제 설명

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

  • 아이디와 비밀번호가 모두 일치하는 회원정보가 있으면 "login"을 return합니다.
  • 로그인이 실패했을 때 아이디가 일치하는 회원이 없다면 “fail”를, 아이디는 일치하지만 비밀번호가 일치하는 회원이 없다면 “wrong pw”를 return 합니다.

제한 사항

  • 회원들의 아이디는 문자열입니다.
  • 회원들의 아이디는 알파벳 소문자와 숫자로만 이루어져 있습니다.
  • 회원들의 패스워드는 숫자로 구성된 문자열입니다.
  • 회원들의 비밀번호는 같을 수 있지만 아이디는 같을 수 없습니다.
  • id_pw의 길이는 2입니다.
  • id_pw와 db의 원소는 [아이디, 패스워드] 형태입니다.
  • 1 ≤ 아이디의 길이 ≤ 15
  • 1 ≤ 비밀번호의 길이 ≤ 6
  • 1 ≤ db의 길이 ≤ 10
  • db의 원소의 길이는 2입니다.

입출력 예

문제 풀이

function solution(id_pw, db) {
  // 첫 번째 방법
  const result = db.filter((id) => id[0] === id_pw[0]);
  if (result.length !== 0) {
    if (result[0][1] === id_pw[1]) return 'login';
    else return 'wrong pw';
  } else return 'fail';
}
function solution(id_pw, db) {
// 두번째 방법
    const [id, pw] = id_pw;
    const new_db = new Map(db);
    return new_db.has(id)
      ? new_db.get(id) === pw
        ? 'login'
        : 'wrong pw'
      : 'fail'; 
}

추가

기존에는 filter를 이용해서 id_pw와 동일한 것중에 pw가 같은게 있는지 비교했다. 이후 다른 사람의 풀이를 봤을 때 map을 이용해서 key와 value 형태로 비교한 방법이 있었는데, 이 방법이 깔끔하고 보기에 좋아서 따로 기록해두었다.

profile
Growing up

0개의 댓글