230127 표현 가능한 이진트리

Jongleee·2023년 1월 27일
0

TIL

목록 보기
166/786

1. 포화 이진 트리를 만들어 주고 dfs호출

for (int i = 0; i < numbers.length; i++) {
	result = 1;
	long number = numbers[i];
	int numberLength = (int)Math.floor(Math.log(number) / Math.log(2)) + 1;
	int exp = 1;
	int treeLength = 0;
	while(treeLength < numberLength) {
		treeLength = (int)Math.pow(2, exp++) - 1;
	}	
    node = new boolean[treeLength];
    int index = treeLength - 1;
    while(true) {
        long div = number / 2;
        long mod = number % 2;
        number = div;
        node[index--] = (mod == 1);
        if (div == 1) {
            node[index] = true;
            break;
        } else if (div == 0)
            break;
    }
    solve(0, treeLength - 1, false);
    answer[i] = result;
}

2. 루트 노드를 찾고 표현 가능 여부를 dfs

public static void solve(int s, int e, boolean isEnd) {
	int mid = (s + e) / 2;
	boolean currentNode = node[mid];
	if (isEnd && currentNode) {
		result = 0;
		return;
	}
	if (s != e) {
		solve(s, mid-1, !currentNode);
		solve(mid+1, e, !currentNode);
	}
}

전체코드

private static boolean[] node; 
private static int result;


public static int[] solution(long[] numbers) {
	int[] answer = new int[numbers.length];
	for (int i = 0; i < numbers.length; i++) {
		result = 1;
		long number = numbers[i];
		int numberLength = (int)Math.floor(Math.log(number) / Math.log(2)) + 1;
		int exp = 1;
		int treeLength = 0;
		while(treeLength < numberLength) {
			treeLength = (int)Math.pow(2, exp++) - 1;
		}

		node = new boolean[treeLength];
		int index = treeLength - 1;
		while(true) {
			long div = number / 2;
			long mod = number % 2;
			number = div;
			node[index--] = (mod == 1);
			if (div == 1) {
				node[index] = true;
				break;
			} else if (div == 0)
				break;
		}
		solve(0, treeLength - 1, false);
		answer[i] = result;
	}
	return answer;
}


public static void solve(int s, int e, boolean isEnd) {
	int mid = (s + e) / 2;
	boolean currentNode = node[mid];
	if (isEnd && currentNode) {
		result = 0;
		return;
	}
	if (s != e) {
		solve(s, mid-1, !currentNode);
		solve(mid+1, e, !currentNode);
	}
}

0개의 댓글