Notice
Recent Posts
Recent Comments
Link
250x250
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- SasS
- string
- leetcode
- 컴포넌트
- sorting
- 파이썬
- 자료구조
- scss
- JavaScript
- greedy
- computed
- CSS
- Algorithm
- JavaSceipt
- dynamic programming
- Python
- array
- java
- 백준
- 코딩테스트
- JS
- 자료형
- 알고리즘
- vue.js
- 변수
- hash table
- 프로그래머스
- HTML
- math
- github
Archives
- Today
- Total
Posis
[프로그래머스] 로그인 성공? 본문
문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/120883
문제 설명
머쓱이는 프로그래머스에 로그인하려고 합니다. 머쓱이가 입력한 아이디와 패스워드가 담긴 배열 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"]] |
입출력 예 설명
입출력 예 #1
- db에 같은 정보의 계정이 있으므로 "login"을 return합니다.
입출력 예 #2
- db에 아이디는 같지만 패스워드가 다른 계정이 있으므로 "wrong pw"를 return합니다.
입출력 예 #3
- db에 아이디가 맞는 계정이 없으므로 "fail"을 return합니다.
나의 풀이
Java
import java.util.Arrays;
class Solution {
public String solution(String[] id_pw, String[][] db) {
String answer = "";
for(int i = 0; i < db.length; i++) {
if(Arrays.deepEquals(id_pw, db[i])) {
answer = "login";
} else if(id_pw[0].equals(db[i][0])){
if(!id_pw[1].equals(db[i][1])) {
answer = "wrong pw";
}
}
}
if(answer == "") {
answer = "fail";
}
return answer;
}
}
JavaScript
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';
}
728x90
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 문자열 밀기 (0) | 2022.12.12 |
---|---|
[프로그래머스] 컨트롤 제트 (0) | 2022.12.12 |
[프로그래머스] 구슬을 나누는 경우의 수 (0) | 2022.12.12 |
[프로그래머스] 소인수분해 (0) | 2022.12.12 |
[프로그래머스] 캐릭터의 좌표 (0) | 2022.12.12 |