인프런 커뮤니티 질문&답변
왜 오답인지 궁금합니다
작성
·
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
질문자
전체 코드 입니다.
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);
}
}





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