해결된 질문
작성
·
40
0
안녕하세요 선생님 코드 참고하면서 풀어봤는데 예시는 맞고 통과를 하지 못하는 상황입니다.
저는 입력으로 온 문자열에 a, n, t, i, c를 제외하고 저장을 시키고
비트가 [k개에서 해당 문자 수 5를 뺀만큼] 켜졌을 때 ret을 구하는 방법으로 풀어봤습니다
어느 부분이 잘못되었는지 알 수 있을까요? 감사합니다!
http://boj.kr/0fd6dc2e0f754f30bb6f726111359f97
답변 2
0
안녕하세요 토이보이님ㅎㅎ
solution(onCnt + 1, mask |= (1 << myAlphabat[idx]), idx + 1);
mask = 0;
mask를 갑자기 0으로 초기화를 해버리면 안됩니다.
지금까지 한것 + (지금의 idx를 |=를 하거나 안하거나)로 로직을 바꿔야 합니다.
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다. toyboy0113님.
질문 내용을 보니 입력으로 받은 문자열 중에서 특정 문자를 제외하고 비트 마스킹을 통해 k개의 비트가 켜진 경우를 계산
하는 로직에서 일부 오류가 있을 가능성이 있습니다.
이와 유사한 질문이 이미 강의 커뮤니티에 여러 번 올라왔고, 그에 대한 답변 링크를 확인하실 수 있습니다.
관련 질문: 4-F 기저사례 질문
k < 0
일 때 0을 반환하는 이유와 배우지 않고 넘어가는 경우 최대값 갱신 방법에 대한 설명도 포함되어 있습니다.관련 질문: 4-A 오답 관련 질문입니다. (to_string 사용 시)
위의 링크들을 참고하여, 비트마스킹과 관련된 논리의 오류를 수정해 보세요.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
아 답변 감사합니다!