Search

    프로그래머스 Lv.1(JS) - 삼총사
    2023.01.11 3 min read

    프로그래머스 Lv.1(JS) - 삼총사

    문제

    삼총사

    문제 설명

    한국중학교에 다니는 학생들은 각자 정수 번호를 갖고 있습니다. 이 학교 학생 3명의 정수 번호를 더했을 때 0이 되면 3명의 학생은 삼총사라고 합니다. 예를 들어, 5명의 학생이 있고, 각각의 정수 번호가 순서대로 -2, 3, 0, 2, -5일 때, 첫 번째, 세 번째, 네 번째 학생의 정수 번호를 더하면 0이므로 세 학생은 삼총사입니다. 또한, 두 번째, 네 번째, 다섯 번째 학생의 정수 번호를 더해도 0이므로 세 학생도 삼총사입니다. 따라서 이 경우 한국중학교에서는 두 가지 방법으로 삼총사를 만들 수 있습니다.

    한국중학교 학생들의 번호를 나타내는 정수 배열 number가 매개변수로 주어질 때, 학생들 중 삼총사를 만들 수 있는 방법의 수를 return 하도록 solution 함수를 완성하세요.


    제한사항

    • 3 ≤ number의 길이 ≤ 13
    • -1,000 ≤ number의 각 원소 ≤ 1,000
    • 서로 다른 학생의 정수 번호가 같을 수 있습니다.

    입출력 예

    numberresult
    [-2, 3, 0, 2, -5]2
    [-3, -2, -1, 0, 1, 2, 3]5
    [-1, 1, -1, 1]0

    정답

    풀이 코드

    function solution(number) {
      let result = 0;
    
      for (let i = 0; i < number.length; i++) {
        for (let j = 1; j < number.length - i; j++) {
          for (let k = 1; k < number.length - i - j; k++) {
            if (number[i] + number[i + j] + number[i + j + k] === 0) result++;
          }
        }
      }
    
      return result;
    }

    풀이 설명

    기준 인덱스를 i라고 하고 두 번째와 세 번째 숫자는 각각 이전 숫자의 인덱스에서 1씩 증가시켜 가며 해당 인덱스값을 사용합니다.

    세 숫자의 합이 0이면 result을 증가시킵니다.


    References

    프로그래머스 연습 - 삼총사

    TAGS

    Algorithm

    알고리즘 문제 풀이

    2023.01.11
    3 min read

    TAGS

    Algorithm