inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

4-F

4-F 시간복잡도 O(2^26) 이면 풀려야 하는 것 아닌가요? ㅠㅠ

3087

작성자 없음

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);
    }
}

c++ 코딩-테스트 java

답변 1

0

큰돌

안녕하세요 ㅎㅎ

작성자가 삭제된 글은 처음보네요.. ㅎㅎ

죄송하지만 C++로만 QA를 받고 있습니다. C++로 포팅해서 질문주세요. ㅎㅎ

 

감사합니다.

코딩 살구 클럽 컴파일 에러

0

4

1

추천 문제

0

7

1

코딩살구클럽 승인

0

9

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

21

2

문제를 고민하는 시간 관련

0

26

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

37

2

코딩살구클럽 승인

0

35

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

33

2

3-F 채점 관련 질문

0

31

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

33

2

코딩살구클럽 승인

0

45

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

54

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

63

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3

코딩 살구 클럽 로그인 문제

0

86

2