프로그래머스 0단계 - 로그인 성공

이종현·2024년 1월 12일
0

코딩테스트

목록 보기
12/24
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입니다.

입출력 예

id_pwdbresult
["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. 문제 이해

  • db에 아이디와 비밀번호가 있는지 체크해서 조건에 맞게 리턴
  • input값이 작기 때문에 시간복잡도는 문제 없음

2. 접근 방법

  • 직관적으로 생각하기
    • db를 반복적으로 돌면서 id_pw에 있는 배열의 아이디 값이 같으면 그 다음 비밀번호 값도 비교한다.
    • 비밀번호가 같으면 login 리턴하고 다르면 wrong pw를 리턴한다.
    • 아이디 값이 다르다면 fail를 리턴한다.

3. 코드 설계

  • 직관적으로 생각하기
  • const id = id_pw[0]
  • const pw = id_pw[1]
  • for(let i = 0; i < db.length; i++)
  • if(db[i][0] === id) →
  • if(db[i][1] === pw) return ‘login’
  • else return ‘wrong pw’
  • else return ‘fail’

4. 코드 구현

function solution(id_pw, db) {
  const id = id_pw[0]
  const pw = id_pw[1]
  let result = ''

  for (let i = 0; i < db.length; i++) {
    if (db[i][0] === id) {
      if (db[i][1] === pw) {
        result = 'login'
        return result
      } else {
        result = 'wrong pw'
        return result
      }
    } else result = 'fail'
  }
  return result
}

다른 사람 풀이

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

회고

자꾸 for문으로만 해결할라고 한다; 나도 배열 고차함수를 이용하고 싶은데 자꾸 까먹는다. 아무래도 일단 코드 설계할 때 일단 5분 정도는 배열 고차함수도 고민해 본 다음에 그래도 안 떠오르면 배열 관련 자료 켜놓고 어떤 고차함수를 적용하면 좋을지 찾아봐서라도 for문 사용하는 건 지양하도록 하자.

profile
데이터리터러시를 중요하게 생각하는 프론트엔드 개발자

0개의 댓글