programmers 코딩테스트 : 평균 구하기

H·2022년 4월 21일
0

Coding Test

목록 보기
6/26

🔔 평균 구하기

📢 문제 설명
정수를 담고 있는 배열 arr의 평균값을 return하는 함수, solution을 완성해보세요.

⛔ 제한사항
arr은 길이 1 이상, 100 이하인 배열입니다.
arr의 원소는 -10,000 이상 10,000 이하인 정수입니다.

평균 : 전체 값을 다 더한 값을 평균 낼 개수만큼 나누기


🔠 첫번째 통과한 코드 forEach()

const arr = [1, 2, 3, 4];
solution(arr);
function solution(x) {
  let answer = 0;
  let total = 0;
  x.forEach((el) => {
    total += el;
  });
  answer = total / x.length;
  return answer;
}

📌 코드 설명

  1. 배열의 전체 값을 다 더한다.
  2. 해당 배열의 length로 나눈다.
  3. 그 값은 answer에 return한다.

forEach()
arr.forEach(callback(currentvalue[, index[, array]])[, thisArg]);
callback: 각 요소에 대해 실행할 함수. 다음 세 가지 매개변수를 받습니다.
currentValue: 처리할 현재 요소. ( 배열의 각각의 item )
index Optional: 처리할 현재 요소의 인덱스. ( 배열의 index )
array Optional: forEach()를 호출한 배열. ( 배열 )
thisArg Optional: callback을 실행할 때 this로 사용할 값.
📍 배열에서만 사용하는 fon문과 비슷한 메서드
📍 forEach() 구문의 인자로 callback 함수를 등록 가능 ,배열의 각 요소가 반복될 떄 등록된 callback 함수 호출, callback 함수에서 배열 요소의 index, 값에 접근 간으하다.
📍 배열의 처음과 끝까지 반복하며, 배열의 item에 접근 가능

🔠 두번째 통과한 코드 for()

 function solution(x) {
      let answer = 0;
      let sum = 0;
      for (let i = 0; i < x.length; i++) {
        sum += x[i];
      }
      answer = sum / x.length;
      console.log(answer);
      return answer;
    }

📌코드설명

forEach() > for()문으로 변환한 형태

🔠 세번째 통과한 코드 reduce()

 function solution(x) {
      let answer = 0;
      answer = x.reduce((a, b) => a + b) / x.length;
      console.log(answer);
      return answer;
    }

reduce()
📍 배열의 각 요소에 대해 주어진 리듀서(reducer) 함수를 실행하고, 하나의 결과값을 반환합니다.
arr.reduce(callback[, initialValue])
callback: 배열의 각 요소에 대해 실행할 함수. 다음 네 가지 인수를 받습니다.
accumulator: 누산기는 콜백의 반환값을 누적합니다. 콜백의 이전 반환값 또는, 콜백의 첫 번째 호출이면서 initialValue를 제공한 경우에는 initialValue의 값입니다.
currentValue: 처리할 현재 요소.
currentIndex Optional: 처리할 현재 요소의 인덱스. initialValue를 제공한 경우 0, 아니면 1부터 시작합니다.
array Optional: reduce()를 호출한 배열.
initialValue Optional: callback의 최초 호출에서 첫 번째 인수에 제공하는 값. 초기값을 제공하지 않으면 배열의 첫 번째 요소를 사용합니다. 빈 배열에서 초기값 없이 reduce()를 호출하면 오류가 발생합니다.

profile
🤘 돌머리도 ROCK이다! 🤘

0개의 댓글