티스토리 뷰
https://www.acmicpc.net/problem/6443
6443번: 애너그램
첫째 줄에 단어의 개수 N 이, 둘째 줄부터 N개의 영단어가 들어온다. 영단어는 소문자로 이루어져 있다. 단어의 길이는 20보다 작거나 같고, 애너그램의 수가 100,000개 이하인 단어만 입력으로 주
www.acmicpc.net
문제
씬디는 애너그램(anagram) 프로그램을 만들어 줄 수 있는 남자를 좋아한다. 참고로 씬디는 매우 예쁘다.
애너그램 프로그램이란, 입력받은 영단어의 철자들로 만들 수 있는 모든 단어를 출력하는 것이다. 가령 "abc" 를 입력받았다면, "abc", "acb", "bac", "bca", "cab", "cba" 를 출력해야 한다.
입력받은 단어내에 몇몇 철자가 중복될 수 있다. 이 경우 같은 단어가 여러 번 만들어 질 수 있는데, 한 번만 출력해야 한다. 또한 출력할 때에 알파벳 순서로 출력해야 한다.
입력
첫째 줄에 단어의 개수 N 이, 둘째 줄부터 N개의 영단어가 들어온다. 영단어는 소문자로 이루어져 있다. 단어의 길이는 20보다 작거나 같고, 애너그램의 수가 100,000개 이하인 단어만 입력으로 주어진다.
출력
N개의 영단어에 대한 모든 가능한 애너그램을 출력한다. 각각의 영단어에 대한 애너그램을 출력할 때, 알파벳 순서로 중복되지 않게 출력한다.
DFS로 모든 단어를 구하고 Set으로 중복을 제거하면 시간 초과가 난다.
Next-Permutation이라는 알고리즘을 새로 배웠다.
설명은 TIL 레파지토리에 적어두었다.
https://github.com/kimhm0728/TIL/blob/main/JAVA/Next-Permutation.md
GitHub - kimhm0728/TIL: 💫 Today I Learned
💫 Today I Learned. Contribute to kimhm0728/TIL development by creating an account on GitHub.
github.com
import java.util.*;
import java.io.*;
public class Main {
static StringBuilder sb = new StringBuilder();
static int N;
static char[] arr;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
N = Integer.parseInt(br.readLine());
for(int i=0;i<N;i++) {
arr = br.readLine().toCharArray();
Arrays.sort(arr);
sb.append(arr).append('\n');
while(next_permutation(arr.length))
sb.append(arr).append('\n');
}
System.out.println(sb);
}
static boolean next_permutation(int n) {
int idx = n - 1;
while(idx > 0 && arr[idx] <= arr[idx - 1])
idx--;
if(idx == 0)
return false;
for(int i=n - 1;i>=idx;i--) {
if(arr[idx - 1] < arr[i]) {
char temp = arr[i];
arr[i] = arr[idx - 1];
arr[idx - 1] = temp;
break;
}
}
Arrays.sort(arr, idx, n);
return true;
}
}
'algorithm > BOJ' 카테고리의 다른 글
[백준/BOJ] 7662번 이중 우선순위 큐 코틀린 풀이 (1) | 2024.09.21 |
---|---|
[백준/BOJ] 2423번 전구를 켜라 자바 풀이 (0) | 2023.03.21 |
[백준/BOJ] 1039번 교환 자바 풀이 (0) | 2023.01.29 |
[백준/BOJ] 5427번 불 자바 풀이 (0) | 2023.01.29 |
[백준/BOJ] 14391번 종이 조각 자바 풀이 (1) | 2023.01.27 |