강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

kym9129님의 프로필 이미지
kym9129

작성한 질문수

자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비

11. 임시반장정하기

왜 오답인지 궁금합니다

작성

·

214

0

안녕하세요. 저는 0번지부터 시작해서 푼 다음에 마지막에 +1로 정답을 넣었고, Set을 사용해서 중복친구를 제거했습니다.

예시와 아래 테스트케이스는 맞게 나오는데, 채점하면 오답이라고 나옵니다. 제가 뭘 놓쳤는지 궁금합니다!

5
1 1 1 1 1
1 1 1 1 1
1 3 4 5 5
3 3 3 3 3
4 4 4 4 4

 

    public static int solution(int n, int[][] arr) {
        Set<Integer> sameClass = new HashSet<>();
        int max = 0;
        int answer = 0;
        for(int i = 0; i < n; i++){
            for(int j = 0; j < n; j++){
                for(int k = 0; k < 5; k++){
                    if(i != j && arr[i][k] == arr[j][k]){
                        sameClass.add(j);
                    }
                }
            }

            if(max < sameClass.size()){
                max = sameClass.size();
                answer = i+1;
            }
            sameClass.clear();
        }

        return answer;
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[][] arr = new int[n][5];
        for(int i = 0 ; i < n; i++){
            for(int j = 0; j < 5; j++){
                arr[i][j] = sc.nextInt();
            }
        }
        int answer = solution(n, arr);
        System.out.println(answer);
    }

답변 2

1

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^
아래와 같은 입력에 대해

3

5 4 4 2 1

1 2 3 4 5

1 2 3 7 8

출력이

0번 친구와 같은반친구=[]

1번 친구와 같은반친구=[2]

2번 친구와 같은반친구=[1]

2

위와 같이 출력됩니다. 그냥 2만 출력하세요.

 

아 이런 말도안되는 실수를😂😂😂 답변 감사합니다!

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

채점사이트에 채점을 해볼 수 있도록 풀코드를 주세요.

kym9129님의 프로필 이미지
kym9129
질문자

전체 코드 입니다.

import java.util.*;

public class Main {

    public static int solution(int n, int[][] arr) {
        Set<Integer> sameClass = new HashSet<>();
        int max = 0;
        int answer = 0;
        for(int i = 0; i < n; i++){
            for(int j = 0; j < n; j++){
                for(int k = 0; k < 5; k++){
                    if(i != j && arr[i][k] == arr[j][k]){
                        sameClass.add(j);
                    }
                }
            }
            System.out.println((i)+"번 친구와 같은반친구="+sameClass);
            if(max < sameClass.size()){
                max = sameClass.size();
                answer = i+1;
            }
            sameClass.clear();
        }

        return answer;
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[][] arr = new int[n][5];
        for(int i = 0 ; i < n; i++){
            for(int j = 0; j < 5; j++){
                arr[i][j] = sc.nextInt();
            }
        }
        
        int answer = solution(n, arr);
        System.out.println(answer);
    }
}
kym9129님의 프로필 이미지
kym9129

작성한 질문수

질문하기