inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

4-F

4-F질문있습니다!

417

이상목

작성한 질문수 7

0

안녕하세요. 선생님

좋은수업 열심히 듣고 있습니다!

4-F문제의 선생님 코드에 대해 질문이 있는데요. 선생님이 만든신 go함수의 기저사례는 index==26일때 발동하잖아요. 그럼 k값이 양수일때, 즉 아직 더 배울 수 있는 상황에서도 count함수를 호출하는 건가요?

감사합니다!

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 상목님 ㅎㅎ

이부분 말씀하시는거죠?

int count(int mask) {
    int cnt = 0;
    for (int word : words) { 
        if(word && (word & mask) == word)cnt++; 
    }
    return cnt;
}
int go(int index, int k, int mask) { 
    if (index == 26) return count(mask);  
}

 

그럼 k값이 양수일때, 즉 아직 더 배울 수 있는 상황에서도 count함수를 호출하는 건가요?

>> 네 맞습니다.

이 문제는 K개 이하가 아니라 K개를 가르쳤을 때의 최대값이니까요.

따라서 보다 정확한코드는 다음과 같이 됩니다.

int go(int index, int k, int mask) {
    if (k < 0) return 0;
    if(index == 26 && k == 0) return count(mask); 
    if (index == 26) return 0;

 

그러나.. k개 이하로 가르쳤을 때의 경우의 수와 k개 가르쳤을 때와 비교했을 때 후자가 더 많거나 같은 것은 자명하기 때문에 그냥 이런식으로 구축해도 정답에는 문제가 없습니다.

int go(int index, int k, int mask) { 
    if (index == 26) return count(mask);  

다만, 상목님이 지적하신대로 count를 더 호출안하게하는게 더 효율적인 코드인 것은 맞습니다. ㅎㅎ

좋은 지적입니다.

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

코딩 살구 클럽 컴파일 에러

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