Hyemi Lee

Hyemi Lee

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

Algorithm, boj, 돌 그룹(12886)

돌 그룹

배운점

  • 큐에 배열형태도 넣을수있다
  • hashset을 이용하면, 중복된 값을 체크할수있다.
  • 규칙을 만들려면 기준값이 필요하다. 여기서는 오름차순으로 정리하는 기준을 가지고 문제풀 수 있다.

풀이

1. 오름 차순으로 정리한후 입력 받은 배열을 큐에 넣는다.
2. 큐에서 배열 하나를 뺀다.
3-1. 첫번째 값이 무조건 제일 작으므로 배열 두개를 새로 만들 수 있다.
 arr[1]*2, arr[2]-arr[1], arr[3]
 arr[1]*2, arr[2], arr[3]-arr[1]
3-2. 오름 차순으로 정리
4. 새로 만든 배열이 이전에 만든적이 있는지 HashSet을 이용하여 확인해준다.
5. 이전에 만든적이 없으면 Queue에 해당 배열을 넣어준다
6. 2~5반복.

핵심

  • 한가지 상황에 대해서 상황이 어떻게 바뀔수 있는지를 알아야 한다.
  • 바뀐 상황이 새로운 상황이면 큐에 삽입

코드

package org.baekjoon;
import java.util.*;
public class test12886_ston {
	static Queue<int[]> q;
	static HashSet<String> hs;
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int[] stone = new int[3];
		int sum = 0;
		for (int i = 0; i < 3; i++) {
			stone[i] = sc.nextInt();
			sum += stone[i];
		}
		if (sum % 3 != 0)
			System.out.println(0);
		else {
			Arrays.sort(stone);
			q = new LinkedList<>();
			hs = new HashSet<>();
			q.offer(stone);
			bfs();
		}
	}
	private static void bfs() {
		while (!q.isEmpty()) {
			int[] stone = q.poll();
			// 셋이 같으면 끝.
			if (stone[0] == stone[1] && stone[1] == stone[2]) {
				System.out.println("1");
				return;
			}
			for (int i = 1; i < 3; i++) {
				int[] newStone = stone.clone();
				newStone[i] = stone[i] - stone[0];
				newStone[0] = stone[0] * 2;
				Arrays.sort(newStone);
				String str = "";
				for (int j = 0; j < 3; j++)
					str += newStone[j] + "";
				// 해당 패턴이 처음 이면 큐와 해쉬셋에 입력한다
				if (!hs.contains(str)) {
					q.offer(newStone);
					hs.add(str);
				}
			}
		}
		System.out.println("0");
	}
}

비슷한 문제 - 물통(2251)


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...