Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 상속
- Final
- 인터페이스
- 와일드카드
- 17472
- 캡슐화
- Encapsulation
- 생성자
- 객체지향
- java
- 다형성
- inheritance
- enum
- python
- 백준
- 추상 클래스
- 객체 지향
- polymorphism
- 프림알고리즘
- this
- abstract
- 열거형
- 내부 클래스
- 버퍼비우기
- 추상화
- 제네릭
- 최소신장트리
- Scanner
- nextInt
Archives
- Today
- Total
쫑쫑이의 블로그
백준 12015 가장 긴 증가하는 부분 수열 2 Java [LIS] 본문
https://www.acmicpc.net/problem/12015
N이 1000000까지니까 NlogN 안으로 풀어야한다
예제
A 10 20 10 30 20 50
D 1 2 1 3 2 4
예제는 중복되는 숫자가 있어서 규칙을 찾기가 힘들다
예제 2
A 11 20 10 30 19 50
D 1 2 1 3 2 4
거리배열을 만들어서 배열 가장 끝값보다 크면 배열에 추가해준다
배열보다 작으면 이진탐색으로 작은값 중에 가장 큰값 찾아서 그 다음 인덱스 값과 교체해준다
import java.io.*;
import java.util.*;
public class Main {
static ArrayList<Integer> arrayList;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int[] arr = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();
arrayList = new ArrayList<>();
arrayList.add(0);
for (int n = 0; n < N; n++) {
if (arrayList.get(arrayList.size()-1) < arr[n]) {
arrayList.add(arr[n]);
continue;
}
binarySearch(arr[n]);
}
System.out.println(arrayList.size()-1);
}
static void binarySearch(int num) {
int l = 0, r = arrayList.size()-1;
while (l < r) {
if (l+1 == r) {
arrayList.set(r, num);
break;
}
int m = (l + r) / 2;
if (num > arrayList.get(m)) {
l = m;
} else {
r = m;
}
}
}
}
찾아보니 Arrays의 메서드에 이진탐색이 있다...
이진탐색에 오버로딩된 메서드에 (배열, to index, from index, key) 값으로 찾을 수 있는게 있다
이 메서드를 사용하면 ArrayList를 사용하지않고 배열을 사용하여 훨씬 쉽고 빠르게 해결할 수 있다!!
이진 탐색 메서드를 사용해서 풀이한 유사 문제(입력값 조건만 다름) 코드
'알고리즘 > 백준' 카테고리의 다른 글
백준 14003 가장 긴 증가하는 부분 수열 5 Java [LIS] (0) | 2022.10.22 |
---|---|
백준 12738 가장 긴 증가하는 부분 수열 3 Java [LIS] (0) | 2022.10.22 |
백준 1644 소수의 연속합 Java [에라토스테네스의 체] (0) | 2022.10.22 |
백준 1504 특정한 최단 경로 Java [다익스트라] (0) | 2022.10.20 |
백준 1916 최소비용 구하기 Java [다익스트라] (0) | 2022.10.20 |