728x90
오늘은 어제 있던 알고리즘 타임어택 해설이 있었다.
369게임
문제 설명
머쓱이는 친구들과 369게임을 하고 있습니다. 369게임은 1부터 숫자를 하나씩 대며 3, 6, 9가 들어가는 숫자는 숫자 대신 3, 6, 9의 개수만큼 박수를 치는 게임입니다. 머쓱이가 말해야하는 숫자 order가 매개변수로 주어질 때, 머쓱이가 쳐야할 박수 횟수를 return 하도록 solution 함수를 완성해보세요.
제한사항
1 ≤ order ≤ 1,000,000
입출력 예
order | result |
3 | 1 |
29423 | 2 |
입출력 예 설명
#1
- 3은 3이 1개 있으므로 1을 출력합니다.
#2
- 29423은 3이 1개, 9가 1개 있으므로 2를 출력합니다.
해설
function solution(order) {
let answer = 0;
const orderStr = order.toString();
for (let i = 0; i < orderStr.length; i++){
if (orderStr[i] === '3' || orderStr[i] === '6' || orderStr[i] === '9'){
answer++
}
}
return answer;
}
로그인 성공?
문제 설명
머쓱이는 프로그래머스에 로그인하려고 합니다. 머쓱이가 입력한 아이디와 패스워드가 담긴 배열 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" |
입출력 예 설명
#1
- db에 같은 정보의 계정이 있으므로 "login"을 return합니다.
#2
- db에 아이디는 같지만 패스워드가 다른 계정이 있으므로 "wrong pw"를 return합니다.
#3
- db에 아이디가 맞는 계정이 없으므로 "fail"을 return합니다.
해설
function solution(id_pw, db) {
// id_pw = []
// db = [[], [], .. ]
// 있으면 > 'login'
// 아이디가 없으면 'fail'
// 패스워드가 틀리면 'wrong pw'
let answer = 'fail';
for (const userInfo of db) {
if (id_pw[0] === userInfo[0]){
// 삼항 연산자
// if - else를 축약해서 하나의 표현식으로 담은 것이에요.
answer = (id_pw[1] === userInfo[1]) ? 'login' : 'wrong pw';
break;
}
}
return answer;
}
아래문제는 해설에서는 제외 되었고 해설 후 따로 풀었다.
각도기
문제 설명
각에서 0도 초과 90도 미만은 예각, 90도는 직각, 90도 초과 180도 미만은 둔각 180도는 평각으로 분류합니다.
각 angle이 매개변수로 주어질 때 예각일 때 1, 직각일 때 2, 둔각일 때 3, 평각일 때 4를 return하도록 solution 함수를 완성해주세요.
예각 : 0 < angle < 90
직각 : angle = 90
둔각 : 90 < angle < 180
평각 : angle = 180
제한사항
0 < angle ≤ 180
angle은 정수입니다.
입출력 예
angle | result |
70 | 1 |
91 | 3 |
180 | 4 |
입출력 예 설명
#1
- angle이 70이므로 예각입니다. 따라서 1을 return합니다.
#2
- angle이 91이므로 둔각입니다. 따라서 3을 return합니다.
#3
- angle이 180이므로 평각입니다. 따라서 4를 return합니다.
풀이
function solution(angle) {
let answer = 0;
if(0 < angle && angle < 90) {
answer = 1;
} else if(angle === 90) {
answer = 2;
} else if(90 < angle && angle < 180) {
answer = 3;
} else {
answer = 4;
}
return answer;
}
'코딩캠프 > 내일배움캠프' 카테고리의 다른 글
[ TIL ] 12.02(금) 15일차 (0) | 2022.12.02 |
---|---|
[ TIL ] 12.01(목) 14일차 (0) | 2022.12.01 |
[ TIL ] 11.29(화) 12일차 (0) | 2022.11.29 |
[ TIL ] 11.28(월) 11일차 (0) | 2022.11.29 |
[ WIL ] 11.21~25 2주차 (0) | 2022.11.27 |