Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

Algorithm, boj, 크게만들기(2812)

문제유형

  • greedy

    해결

    1. 처음도전 실패
    • 3자리를 뽑는 거라면 0부터 전체길이-3까지 중 가장큰수를 찾고, 그 가장 큰 수 다음부터 전체길이-2까지 중 가장큰수찾고...이런식으로 구했는데 (1 ≤ K < N ≤ 500,000) 이 조건 때문에 당연히 실패할것같았다 2. 스택을 이용해서 구현하려고 했으나 마지막에 결과값을 반대로 출력해야 하는것이 막혀서 deque로 뽑기로했다

3.

  • 큐가 비어있으면 큐에 숫자를 추가하고,
  • 큐가 비어있지않으면 큐의 마지막 숫자와 들어갈 숫자를 비교한다
  • 들어갈 숫자가 더 크다면 마지막 숫자를 제거하고, 삭제할 숫자k–를 해준다
    • 삭제할 숫자가 남아있고 큐가 비어있지 않을때가지 해당 비교문을 수행한다

한줄평

  • deque를 처음 공부하게되었다
  • 첫째. 스택,큐를 이용해서 풀려는 시도를 못했다
  • 둘째. 문제 풀이 방식을 코드화 해내지 못했다
package org.baekjoon;
import java.io.*;
import java.util.*;
public class test2812_greedy_makeBig {
	public static void main(String[] args) throws IOException {
		int n,k;
		String s;
		char[] temp;
		Deque<Integer> dq = new LinkedList<Integer>();
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
		StringTokenizer st;
		st = new StringTokenizer(br.readLine());
		n = Integer.parseInt(st.nextToken());
		k = Integer.parseInt(st.nextToken());
		s = br.readLine();
		for (int i=0; i<n; i++) {
			// k : 제거할 수 , 큐가 비어있지않을때 / 새로들어올 수가 마지막 숫자보다 작거나 같을때까지 마지막 숫자 삭제
			while (k>0 && !dq.isEmpty() && dq.peekLast() < s.charAt(i) - '0') {
				dq.removeLast();
				--k;	// 숫자를 제거 했으므로 k--해준다
			}
			dq.addLast(s.charAt(i) - '0');
		}
		while(!dq.isEmpty() && n-k > 0) {
			bw.write(String.valueOf(dq.pollFirst()));
			++k;
		}
		bw.flush();
		bw.close();
	}
}

Reference


Share on

Twitter Facebook LinkedIn

You may also enjoy

Redis Stream

2021年04月28日

Stream Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다. 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다. 기존 데이터를 수정하지 않고 오직 추가로 발생합니다. 이런 종류의 데이터를 stream or log데이터...

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...