자료구조 및 알고리즘/JavaScript Practice

JS Practice) 프로그래머스 : 로그인 성공?

Ryomi 2023. 4. 7. 09:44
728x90
반응형

 

 

로그인 성공?

문제설명 :

머쓱이는 프로그래머스에 로그인하려고 합니다. 머쓱이가 입력한 아이디와 패스워드가 담긴 배열 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입니다.

 

입출력 예

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"

 

접근

:  db를 반복문을 돌려, id가 db에 포함된 경우와 그렇지 않는 경우, id가 포함되었다면 pw가 db에 포함 되었는가를 기준으로 하여 값을 return 하였다. 

function solution(id_pw, db) {
    for(const el of db){
        if(el.includes(id_pw[0])){
            return el.includes(id_pw[1]) ? 'login' : 'wrong pw' 
        }
    }
    return 'fail'
}

 

solution

case: ["meosseugi", "1234"], [["rardss", "123"], ["yyoom", "1234"], ["meosseugi", "1234"]]

function solution(id_pw, db) {
  const [id, pw] = id_pw; // [ 'meosseugi', '1234' ]
  const map = new Map(db); // Map(3) { 'rardss' => '123', 'yyoom' => '1234', 'meosseugi' => '1234' }
  return map.has(id) ? (map.get(id) === pw ? 'login' : 'wrong pw') : 'fail';
}

// 구조분해할당으로 id와 pw를 나눈 후 Map을 사용해 db에서 id는 key로, pw는 값으로 설정한다. 

// map이 id를 가지고 있는지 여부를 확인해 없으면  'fail'을 반환한다.

// map이 id를 가지고 있는 경우, 해당 id의 value 값이 pw와 동일하면 'login', 아니면 'wrong pw'를 반환한다.

// map 사용법에 익숙해지기!!

728x90
반응형