목록알고리즘 (266)
Dev.baelanche
트리의 성질을 이용하여 풀어야하는 문제이다. 1. 입력값으로 트리를 만든다. 2. DFS 를 통해 컴포넌트 별로 간선 개수, 노드 개수를 각각 구한다. 3. 노드 개수 - 1 = 간선 개수 를 만족해야 트리이다. 4. 양방향으로 구현하였으므로 간선/2 를 해주었다. public class Main { static int tree[][]; static boolean visited[]; static boolean vertexes[]; public static void main(String[] args) throws Exception { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); BufferedWriter bw = new..
입력값으로 트리를 구성한 후 DFS 를 한다. 부모 노드를 저장할 배열을 만들어 DFS 도중에 부모 노드 정보를 저장해주면 된다. public class Main { static int parents[]; static ArrayList nodes; static boolean visited[]; public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); int n = Integer.parseIn..
입력이 문자이므로 캐릭터형을 정수형으로 바꾸어 트리를 만들었다. 출력할때만 다시 캐릭터형으로 출력했다. public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); sc.nextLine(); Tree t = new Tree(n); while(n-->0) { char[] c = sc.nextLine().toCharArray(); t.setChildren(c[0]-65, c[2]-65, c[4]-65); } t.preorder(0); System.out.println(); t.inorder(0); System.out.println(); t.postorder..
풀이 1. 입력한 소수들을 배열에 저장하고 우선순위큐(최소힙)에 담는다. 2. 우선순위큐의 top을 제거하고 top과 1번에서 저장한 배열의 각 인덱스를 곱하여 큐에 담는다. 3. 2번을 반복한다. 위 풀이대로 진행하면 중복된 수들도 큐에 담기게 되는데, 이 부분만 예외처리 하면 시간초과 없이 문제를 풀 수 있다. public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); PriorityQueue pq = new PriorityQueue(); int k = sc.nextInt(); int n = sc.nextInt(); int a[] = new int[k]; for(int i=0; i
문제 설명대로 최대힙을 만들고 n번째까지 빼면서 출력했더니 시간초과가 났다. 우선순위큐가 insert, delete 할때 언제나 정렬된다는 성질을 기억해두면 문제에 접근할 수 있다. 1. 최소힙을 만든다. 2. i번째 행을 모두 집어넣는다. 3. i+1번째 행을 모두 집어넣고 크기가 n이 될때까지 제거한다. 4. n-1 행까지 2, 3번을 반복한다. 최소힙을 구현했으므로 4번까지 진행하면서 작은 수는 모두 제거된다. 남은 수의 개수는 n개 이고 오름차순 정렬이므로 top을 출력해주면 되겠다. public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); ..
1. 최소힙에 카드 묶음을 담는다. 2. 카드 2개를 골라서 비교한다. 3. 2번에서 비교완료한 카드 묶음을 다시 카드 묶음에 담는다. 4. 2, 3번을 반복하는데 힙의 사이즈가 0이면 비교완료한 카드 묶음이 있어도 담지 않아야 한다. public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); MinHeap h = new MinHeap(100001); int n = sc.nextInt(); for(int i=0; i1; i/=2) { if(heap[i/2] > heap[i]) swap(i/2, i); else break; } } public int delete() { if(size == 0..
1부터 n-1 까지 최대힙으로 넣어준다. 마지막으로 배열의 n 자리에 1을 넣어주면 스왑이 가장 많은 힙 구조가 완성된다. public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int a[] = new int[n+1]; for(int i=1; i1; j/=2) a[j] = a[j/2]; a[1] = i+1; } a[n] = 1; for(int i=1; i
배열에 대해서 방문한 적이 없고 땅이라면 인접한 땅에 대해서 DFS 를 한다. DFS 한 컴포넌트의 개수를 세어주면 된다. public class Main { static int w; static int h; static int a[][]; static boolean visited[][]; public static void main(String[] args) { Scanner sc = new Scanner(System.in); while(true) { w = sc.nextInt(); h = sc.nextInt(); if(w == 0 && h == 0) break; a = new int[h][w]; visited = new boolean[h][w]; for(int i=0; i