전체 글
백준[10974] - 모든 순열 (Kotlin)
import java.io.BufferedReader import java.io.BufferedWriter import java.io.InputStreamReader import java.io.OutputStreamWriter fun main() { val br = BufferedReader(InputStreamReader(System.`in`)) val bw = BufferedWriter(OutputStreamWriter(System.out)) val N = br.readLine().toInt() val visited = Array(N+1) { 0 } val selected = Array(N) { 0 } fun dfs(k: Int) { if (k >= N) { for (i in selected.indi..
백준[2580] - 스도쿠 (Kotlin)
import java.io.BufferedReader import java.io.BufferedWriter import java.io.InputStreamReader import java.io.OutputStreamWriter fun main() { var isFinished = false val br = BufferedReader(InputStreamReader(System.`in`)) val bw = BufferedWriter(OutputStreamWriter(System.out)) val board = Array(9) { mutableListOf() } for (i in 0 until 9) { board[i] = br.readLine().split(" ").map { it.toInt() }.toMu..
백준[6443] - 애너그램 (Kotlin)
import java.io.BufferedReader import java.io.BufferedWriter import java.io.InputStreamReader import java.io.OutputStreamWriter fun main() { val br = BufferedReader(InputStreamReader(System.`in`)) val bw = BufferedWriter(OutputStreamWriter(System.out)) var strs = charArrayOf() var visited = arrayOf() var selected = arrayOf() fun dfs(k: Int) { if (k == strs.size) { for (i in strs.indices) { bw.wri..
백준[1182] - 부분수열의 합 (Kotlin)
import java.io.BufferedReader import java.io.BufferedWriter import java.io.InputStreamReader import java.io.OutputStreamWriter fun main() { val br = BufferedReader(InputStreamReader(System.`in`)) val bw = BufferedWriter(OutputStreamWriter(System.out)) val (N, S) = br.readLine().split(" ").map { it.toInt() } val nums = arrayListOf() br.readLine().split(" ").map { nums.add(it.toInt()) } var count ..
스케줄러를 통한 멀티스레딩, subscribeOn, observeOn
스케줄러(Scheduler) 스케줄러는 Reactive X에서 멀티스레딩을 수행할 수 있도록 스레드 풀을 생성하고 다른 스레드에서 실행할 수 있게 해준다. Reactive X에서는 미리 정의된 스케줄러를 제공하며, 아래와 같은 종류와 사용 용도를 가진다. Schedulers.io() : * I/O 관련 작업을 수행할 수 있는 무제한의 워커 스레드. 무제한으로 워커 스레드를 생성할 수 있어 OutOfMemory를 야기할 수 있으니 주의하여 용도에 맞게 사용하여야 한다. * I/O 관련 작업 : 파일 시스템, DB 등의 작업 Schedulers.computation() : CPU의 코어 수와 동일한 수의 스레드를 가지는 스레드 풀을 제공한다. CPU 코어를 사용하는 복잡한 계산 작업에 사용하는 스케줄러이다...
연산자 - 결합, 그룹핑, 필터링 응용, 오류처리
1. startWith startWith 연산자를 통해 기존 observable의 앞에 새로운 observable을 결합 할 수 있다. fun main() { val observable = Observable.range(11, 10) val observable2 = Observable.range(1, 10) observable .startWith(observable2) .subscribe { result -> println("onNext = $result") } } //onNext = 1 //onNext = 2 //onNext = 3 //onNext = 4 //onNext = 5 //onNext = 6 //onNext = 7 //onNext = 8 //onNext = 9 //onNext = 10 //on..
연산자 - 필터링, 변환, 축소
연산자 (Operator) Observable , Flowable을 피연산자로 사용해 변환된 새로운 Observable, Flowable을 반환하는 함수 필터링 연산자 1. debounce debounce 연산자는 아이템의 발행 이후 특정 시간이 지난 후에 다운스트림으로 해당 아이템이 전달될 수 있도록 한다. ex) EditText에서 사용자가 입력 할 때마다 검색이 수행되는 것이 아닌 입력 한 뒤 n초가 지난 후에 검색이 수행되도록 할 때 fun main() { val observable = Observable.create { it.onNext("H") runBlocking { delay(100) } it.onNext("He") runBlocking { delay(100) } it.onNext("Hel..
Cold Observable / Hot Observable
Cold Observable Cold Observable은 각 observer가 observable을 구독 할 때마다 구독 된 시기에 상관없이 늘 처음부터 배출 된 값을 온전히 받을 수 있는 형태를 말한다. 여태까지 알아봤던 create, from, just와 같은 팩토리 메서드들은 모두 이러한 Cold Observable에 해당한다. fun main() { val coldObservable = Observable.just(1, 2, 3, 4) val observer1 = object : Observer { override fun onSubscribe(d: Disposable) { println("observer1 onSubscribe") } override fun onNext(t: Int) { prin..
Observable / Observer
Observable 옵저버블(Observerble)은 데이터를 소모하는 컨슈머(Observer)가 소모할 수 있는 데이터를 내보내주는 역할을 한다. 기존 iterator에서 값을 가져오는 pull 방식이 아니라 옵저버블에서 값을 내보내는 push 방식을 채택함을 알 수 있다. 옵저버 패턴을 사용하여 옵저버블을 구독하는 옵저버 측에서 옵저버블이 데이터를 내보낼 때 이를 사용한다. Observable의 동작 Observable은 데이터에 대한 처리를 할 수 있는 3가지 메소드를 가진다. onNext : 해당 메소드를 통해 옵저버블은 옵저버에게 데이터를 내보낸다. onComplete : 해당 메소드를 통해 옵저버블은 옵저버에게 모든 아이템의 발행이 완료되었음을 알린다. 터미널 메소드로써, 마지막 아이템까지 발..
Reactive Programming
리액티브 프로그래밍 (Reactive Programming) 리액티브 프로그래밍(Reactive Programming) : 데이터의 흐름과 변경사항에 대한 전파에 대한 프로그래밍 패러다임. 예를 들어, 데이터 A의 변화에 따라 데이터 B의 값이 변화하는 방식을 리액티브 프로그램이라 칭함. 리액티브 프로그래밍 방식은 작성된 코드가 정해진 순서대로 수행되는 명령형 프로그래밍 방식과는 다르게 데이터의 흐름에 따라 코드가 수행되는 방식을 취한다. 즉, 프로그램이 아닌 주변의 데이터의 변경에 따른 이벤트가 흐름을 주도하는 방식이다. 리액티브 프로그래밍의 특징 함수형 프로그래밍 방식을 통해 콜백과 같은 방식에서 사이드 이펙트가 없으므로 스레드에 안전하다. 또한, 스케줄러 등을 활용하여 스레드를 활용한 비동기 처리가..