반응형
문제 설명
2016년 1월 1일은 금요일입니다. 2016년 a월 b일은 무슨 요일일까요? 두 수 a ,b를 입력받아 2016년 a월 b일이 무슨 요일인지 리턴하는 함수, solution을 완성하세요. 요일의 이름은 일요일부터 토요일까지 각각 SUN,MON,TUE,WED,THU,FRI,SAT 입니다. 예를 들어 a=5, b=24라면 5월 24일은 화요일이므로 문자열 "TUE"를 반환하세요. |
제한 조건
|
초기 코드
function solution(a, b) {
var answer = '';
return answer;
}
코드 풀이 설명
function solution(a, b) {
// week라는 변수에 일요일부터 토요일까지의 요일을 넣어준다.
let week = ['SUN', 'MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT'];
// ``을 사용하게 되면 ${ } 사이에 변수나 연산 등을 삽입할 수 있게 된다.
let date = new Date(`2016-${a}-${b}`);
// getDay()함수는 날짜의 요일을 받아오는 함수로 일요일부터 토요일까지 0부터 6을 반환
let day = date.getDay();
// 최종 결과는 week의 [i]번째 인덱스를 리턴
return week[day];
}
// console.log(solution(5, 24))
- 먼저 week라는 변수에 일요일부터 토요일까지를 담아준다
- 두번째로 new Date 함수를 통해 날짜를 입력해준다.
- 여기서 ``(백틱)을 사용하게 되는데 ``을 사용하게 될 경우 ${}안에 받아온 변수나 연산 등을 삽입할 수 있게된다.
- 날짜를 받아왔다면 요일을 받아오는 함수인 getDay() 함수를 이용하여 요일을 알아낸다.
- getDay() 함수는 일요일부터 토요일까지를 각각의 숫자인 0부터 6까지로 반환한다.
- 최종적으로 week[day]를 리턴하게 되면 day 안에 0부터 6까지의 숫자가 담기면서 week의 [ ]번째 인덱스를 출력할 수 있게 된다.
백틱( ` ` )과 달러( ${ } ) 사용법 : 자바스크립트 템플릿 리터럴
템플릿 리터럴은 ES6부터 새로 도입된 문자열 표기법으로 문자열을 생성하 때 따옴표 대신 백틱(``)을 이용할 수 있다.
템플릿 리터럴의 기능
- 백틱으로 띄어쓰기나 줄바꿈이 가능해진다
- ${ } 안에 변수나 연산 등을 삽입할 수 있게된다.
- 기존의 따옴표 방식에서는 + 연산자로 여러번 이어붙여야 했다면 `` 안에서는 그럴 필요가 없다.
// 기존 코드
let item = "우산"
let price = 5000
console.log(item + "의 가격은" + " " + price + "원 입니다.") // 우산의 가격은 5000원 입니다.
// 백틱과 달러 사용
let item = "우산"
let price = 5000
console.log(`${item}의 가격은 ${price}입니다.`) // 우산의 가격은 5000원 입니다.
Date 생성 방법
- new Date()
- () 안에 아무런 인수를 전달하지 않으면 현재 날짜와 시간을 리턴
- new Date("날짜를 나타내는 문자열")
- 인수로 날짜를 나타내는 문자열을 전달하면 날짜와 시간을 나타내는 인스턴스를 리턴
- Date 생성 시 사용 가능한 날짜 양식
- ISO 날짜 양식 : YYYY-MM-DDTHH:MM:SS
- Long 날짜 양식 : MMM DD YYYY / DD MMM YYYY
- Short 날짜 양식 : MM DD YYYY / YYYY MM DD
- Full 날짜 양식 : Thu Mar 14 2022 13:32:00 GMT+0900 (대한민국 표준시)
프로그래머스 코딩테스트 연습 - 2016년
프로그래머스 코딩테스트 연습 - 다른 문제 풀이(자바스크립트)
반응형