본문 바로가기
(문제풀이)

프로그래머스(java) : 삼총사

by cogito-new 2022. 10. 18.
  • 삼총사
문제 설명

한국중학교에 다니는 학생들은 각자 정수 번호를 갖고 있습니다. 이 학교 학생 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

입출력 예 설명

입출력 예 #1

  • 문제 예시와 같습니다.

입출력 예 #2

  • 학생들의 정수 번호 쌍 (-3, 0, 3), (-2, 0, 2), (-1, 0, 1), (-2, -1, 3), (-3, 1, 2) 이 삼총사가 될 수 있으므로, 5를 return 합니다.

입출력 예 #3

  • 삼총사가 될 수 있는 방법이 없습니다.

프로그래머스 입력

 

풀이 과정 :

배열의 0, 1, 2 // 0, 1, 3 //  ~~ 끝까지 중첩 for 문을 사용

→ 실행 결과의 문제가 예상되었기에 삼중 for 문까지는 사용하지 않으려 의도했음.

(삼중 for 문과 비교하지는 못헀음)

 

while에 저장한 start 변수로 배열의 0번째 인덱스부터 배열의 길이 -2 까지 반복하면서 

2, 3번째 점수의 합을 구하도록 이중 for 문을 작성함.

 

→풀이 과정에서 이클립스를 활용해서 잦은 수정을 함 (배열의 범위 지정시에)

차후 다시 반복문의 크기 지정을 해 볼 필요가 있음.

class Solution {
    public int solution(int[] number) {
        int answer = 0;
		
		int start = 0;
		while(start <= number.length-3 ) {
		
		for(int i = start+1; i< number.length; i++) {
			for( int j = i+1; j< number.length; j++) {
				if(number[start] + number[i] + number[j] == 0) {
					answer++;
				}
				//System.out.println(number[start] + " : " + number[i] + " : " + number[j]);
			}
		}
		
		start ++;
		}
        
        return answer;
    }
}

 

반응형