배열 2개로 푸는 것도 괜찮은 방법인가요 ?
294
작성한 질문수 22
import java.util.*;
import java.io.*;
public class P03_결혼식 {
public static void main(String[] args) throws Exception {
// 초기 세팅
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int[] starts = new int[73];
int[] ends = new int[73];
for (int i=0; i<N; i++) {
StringTokenizer st = new StringTokenizer(br.readLine());
int start = Integer.parseInt(st.nextToken());
int end = Integer.parseInt(st.nextToken());
starts[start]++;
ends[end]++;
}
// 로직
int max = 0;
int count = 0;
for (int i=0; i<starts.length; i++) {
count += starts[i];
count -= ends[i];
max = Math.max(max, count);
}
// 출력
System.out.println(max);
}
}
저는 이렇게 풀었는데 따로 정렬하는 Class 안 만들고 이렇게 하는것도 괜찮나여 ? 방대한 데이터가 들어왔을 경우에도 문제없는 코드인지 궁금합니다 !
답변 1
0
안녕하세요^^
이 문제만 놓고 보면 잘 하신 코드입니다. 스스로 이렇게 아이디어를 내서 풀다보면 문제해결력이 엄청 좋아질 겁니다. 피로연 기간이 3일로 정해져 있어 배열의 인덱스 번호를 시간으로 간주하고 풀어도 큰 상관은 없습니다. 참석하는 친구 인원수 N이 크게 들어와도 문제없는 코드입니다.
하지만 만약 피로연 기간이 200,000만일까지 들어온다고 한다면 실제 피로연에 참석하는 친구가 10명 정도밖에 안되도 starts, ends 배열은 5,000,000 크기를 잡아야 합니다. 즉 피로연 기간이 엄청 커지면 위 코드는 공간을 너무 낭비하는 코드가 됩니다. 이 문제 스타일은 영상의 방법을 추천합니다.
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
0
34
2
갑자기 채점 사이트가 바뀌었어요
0
35
1
문제 리스트 페이지
0
30
1
채점 사이트 관련 질문드립니다
0
24
1
봉우리 문제 질문입니다
0
85
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
65
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
72
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
67
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
85
2
6-7 강의에서
0
48
1
6-6. 장난꾸러기 질문 있습니다.
0
46
1
강의 수강후 코딩테스트
0
111
1
answer 변수 사용 여부
0
46
1
2중 for문
1
85
2
2-11. 임시반장정하기 (Runtime Error)
0
63
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
70
1
이런 풀이는 어떨까요
0
44
1
자바 스트림 방식의 효율성 질문 드립니다.
0
57
1
알고리즘 자료 구조들..
0
63
1
StringBuilder vs BufferdWriter
0
48
1
원더랜드(프림)
0
50
1
이런 코드는 어떤가요?
0
61
1
bfs 풀이
0
57
1
병합정렬
0
57
1





