► JS Algorithm/Programmers

[Programmers] JavaScript 알고리즘 | Lv.0 조건에 맞게 수열 변환하기 3

다람트리 2023. 12. 15. 12:39
반응형

🔒 문제 설명

정수 배열 arr와 자연수 k가 주어집니다.

만약 k가 홀수라면 arr의 모든 원소에 k를 곱하고, k가 짝수라면 arr의 모든 원소에 k를 더합니다.

이러한 변환을 마친 후의 arr return 하는 solution 함수를 완성해 주세요.


🔒 제한사항 

  • 1 ≤ arr의 길이 ≤ 1,000,000
    • 1 ≤ arr의 원소의 값 ≤ 100
  • 1 ≤ k ≤ 100

🔒 입출력 예

arr k result
[1, 2, 3, 100, 99, 98] 3 [3, 6, 9, 300, 297, 294]
[1, 2, 3, 100, 99, 98] 2 [3, 4, 5, 102, 101, 100]

 


🔒 입출력 예 설명

입출력 예 #1

  • 주어진 k인 3은 홀수이므로, 전체 배열에 3을 곱합니다. 따라서 [3, 6, 9, 300, 297, 294]을 return 합니다.

입출력 예 #2

  • 주어진 k 2 짝수이므로, 전체 배열에 2 더합니다. 따라서 [3, 4, 5, 102, 101, 100] return 합니다.

 

🔐 solution of mine

map()

      const solution = (arr, k) =>
        console.log(k % 2 ? arr.map((v) => v * k) : arr.map((v) => v + k));

      solution([1, 2, 3, 100, 99, 98], 3); // expected output: [3, 6, 9, 300, 297, 294]
      solution([1, 2, 3, 100, 99, 98], 2); // expected output: [3, 4, 5, 102, 101, 100]

 


 

🔐 solution of others 

map()

      const solution = (arr, k) =>
        console.log(arr.map((v) => (k % 2 ? v * k : v + k)));

      solution([1, 2, 3, 100, 99, 98], 3); // expected output: [3, 6, 9, 300, 297, 294]
      solution([1, 2, 3, 100, 99, 98], 2); // expected output: [3, 4, 5, 102, 101, 100]

 

 

나는 map 안에서 조건을 돌렸는데, 

여기서는 map 안에 조건문을 돌려서 코드가 짧아졌다

 

 

반응형