[프로그래머스] 점의 위치 구하기
카테고리 : 컴퓨터 공학
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 점의 위치 구하기 · js 점의 위치 구하기
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 점의 위치 구하기 · js 점의 위치 구하기
문제 설명
사분면은 한 평면을 x축과 y축을 기준으로 나눈 네 부분입니다. 사분면은 아래와 같이 1부터 4까지 번호를매깁니다.
- x 좌표와 y 좌표가 모두 양수이면 제1사분면에 속합니다.
- x 좌표가 음수, y 좌표가 양수이면 제2사분면에 속합니다.
- x 좌표와 y 좌표가 모두 음수이면 제3사분면에 속합니다.
- x 좌표가 양수, y 좌표가 음수이면 제4사분면에 속합니다.
x 좌표 (x, y)를 차례대로 담은 정수 배열 dot
이 매개변수로 주어집니다. 좌표 dot
이 사분면 중 어디에 속하는지 1, 2, 3, 4 중 하나를 return 하도록 solution 함수를 완성해주세요.
제한사항
dot
의 길이 = 2dot[0]
은 x좌표를,dot[1]
은 y좌표를 나타냅니다- 500 ≤
dot
의 원소 ≤ 500 dot
의 원소는 0이 아닙니다.
입출력 예
dot | result |
---|---|
[2, 4] | 1 |
[-7, 9] | 2 |
입출력 설명
입출력 예 #1
dot
이 [2, 4]로 x 좌표와 y 좌표 모두 양수이므로 제 1 사분면에 속합니다. 따라서 1을 return 합니다.
입출력 예 #2
dot
이 [-7, 9]로 x 좌표가 음수, y 좌표가 양수이므로 제 2 사분면에 속합니다. 따라서 2를 return 합니다.
나의 첫번째 풀이
function solution(dot) {
if (dot[0] > 0 && dot[1] > 0) {
return 1;
}
if (dot[0] < 0 && dot[1] > 0) {
return 2;
}
if (dot[0] < 0 && dot[1] < 0) {
return 3;
}
if (dot[0] > 0 && dot[1] < 0) {
return 4;
}
}
나의 두번째 풀이(Code Refactoring)
function solution(dot) {
const [first, second] = dot;
if (first * second < 0) {
if (first < 0) {
return 2;
} else {
return 4;
}
}
if (first * second > 0) {
if (first < 0) {
return 3;
} else {
return 1;
}
}
}
// 구조 분해 할당을 사용 , if문을 좀 더 개선해야함
참고 할 만한 다른 사람의 코드
function solution(dot) {
const [num, num2] = dot;
const check = num * num2 > 0;
return num > 0 ? (check ? 1 : 4) : check ? 3 : 2;
}
// 같은 구조 분해 할당을 사용했지만 삼항연산자로 좀더 깔끔하다