-
[Programmers] JavaScript 알고리즘 | Lv.0 조건에 맞게 수열 변환하기 1► JS Algorithm/Programmers 2023. 12. 6. 12:54반응형
🔒 문제 설명
정수 배열 arr가 주어집니다. arr의 각 원소에 대해 값이 50보다 크거나 같은 짝수라면 2로 나누고, 50보다 작은 홀수라면 2를 곱합니다. 그 결과인 정수 배열을 return 하는 solution 함수를 완성해 주세요.
🔒 제한사항
- 1 ≤ arr의 길이 ≤ 1,000,000
- 1 ≤ arr의 원소의 값 ≤ 100
🔒 입출력 예
arr result [1, 2, 3, 100, 99, 98] [2, 2, 6, 50, 99, 49]
🔒 입출력 예 설명
입출력 예 #1
- 1, 3은 50 미만의 홀수 이므로 2를 곱하고, 100, 98은 50 이상의 짝수이므로 2로 나눕니다.
- 나머지 값들은 변경 조건에 해당하지 않으므로 바꾸지 않습니다.
- 따라서 [2, 2, 6, 50, 99, 49]를 return 합니다.
🔐 solution of mine
map()
const solution = (arr) => console.log( arr.map((v, i, a) => v < 50 && v % 2 === 1 ? v * 2 : v >= 50 && v % 2 === 0 ? v / 2 : v ) ); solution([1, 2, 3, 100, 99, 98]); // expected output: [2, 2, 6, 50, 99, 49]
반응형'► JS Algorithm > Programmers' 카테고리의 다른 글
[Programmers] JavaScript 알고리즘 | Lv.0 홀짝에 따라 다른 값 반환하기 (0) 2023.12.12 [Programmers] JavaScript 알고리즘 | Lv.0 글자 이어 붙여 문자열 만들기 (1) 2023.12.07 [Programmers] JavaScript 알고리즘 | Lv.0 0 떼기 (1) 2023.12.05 [Programmers] JavaScript 알고리즘 | Lv.0 문자열을 정수로 변환하기 (1) 2023.12.05 [Programmers] JavaScript 알고리즘 | Lv.0 마지막 두 원소 (0) 2023.12.05 - 1 ≤ arr의 길이 ≤ 1,000,000