4-F 시간복잡도 O(2^26) 이면 풀려야 하는 것 아닌가요? ㅠㅠ
3081
작성자 없음
작성한 질문수 0
0
자바가 느려서인지, 아니면 제가 첨부터 접근을 잘못한건지 모르겠습니다. ㅠㅠ
package lecture4;
import java.util.*;
public class Prob1062 {
static List<Set<Character>> sets = new ArrayList<>();
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int k = sc.nextInt();
if(k<5){
System.out.println(0);
return;
}else if (k==26){
System.out.println(n);
return;
}
List<String> list = new ArrayList<>();
for (int i = 0; i < n; i++) { // 문자열 입력 받기
String str = sc.next();
list.add(str);
Set<Character> set = new HashSet<>(); // 각 문자열의 문자들을 Set에 저장.
for (char c : str.toCharArray()) {
set.add(c);
}
sets.add(set);
}
List<Set<Character>> filtered = new ArrayList<>();
for (int i = 0; i < n; i++) { // K 보다 많은 알파벳으로 이루어진 경우 제외
if(sets.get(i).size()<=k){
filtered.add(sets.get(i));
}
}
List<Integer> masks = new ArrayList<>();
for (Set<Character> set : filtered) { // Set의 각 알파벳을 대응되는 비트마스크로 표현
masks.add(setToMask(set));
}
int mask = 1;
int max = 0;
while (mask < (1<<26)-1){ // 모든 경우의 수 탐색
if(Integer.bitCount(mask)>k){ // 비트마스크의 1 개수가 k 보다 크면 다음 경우로 넘어가기
mask++;
continue;
}
int count = 0;
for (Integer m : masks) { // 문자열을 비트마스크로 표현한 것을 비교해서 읽을 수 있는건지 개수 샘
if((mask & m) == m){
count++;
}
}
max = Math.max(max,count); // 최대값 저장
mask++;
}
System.out.println(max);
}
private static int setToMask(Set<Character> set){
int[] num = new int[26];
for (Character character : set) {
num[25 - (character-'a')] = 1;
}
StringBuffer sb = new StringBuffer();
for (int i : num) {
sb.append(i);
}
return Integer.parseInt(sb.toString(),2);
}
}
답변 1
5-B
0
16
2
4 - A
0
33
2
코딩살구클럽 입장이 안됩니다
0
82
2
4-F 경우의 수 질문입니다.
0
35
2
코딩살구클럽 가입이 안됩니다.
0
85
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
63
1
교안 158페이지 문의드립니다
0
46
2
코딩살구클럽 관련 건의사항
0
119
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
45
1
진행 방법 질문드립니다!
0
83
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
64
2
2주차 개념#12 트리 순회
0
33
2
백준사이트가 종료된다고 합니다.
0
318
2
백준 서비스 종료
9
953
1
sk 하이닉스 코테 대비
0
388
2
3-G 최댓값 질문
0
54
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
66
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
69
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
186
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
74
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
66
2





