인프런 커뮤니티 질문&답변

전호영님의 프로필 이미지
전호영

작성한 질문수

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

1-K

안녕하세요 선생님. 반례를 찾지 못해 질문드립니다.

작성

·

66

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

안녕하세요 선생님.

입력받은 문자열을 map을 사용해 알파벳 당 개수로 저장했습니다.

홀수가 2개 이상이면 sorry를 출력하도록 했습니다.

홀수가 1개인 경우, 홀수 알파벳의 개수 -1 을 하고 , 홀수 알파벳을 저장했습니다.

그 후 다시 루프를 돌면서

각 알파벳 개수의 절반만큼 오름차순으로 문자열을 만들고,

미리 저장해둔 홀수 알파벳 1개를 더한 뒤 , 오름차순 문자열을 뒤집어서 더하는 방식으로 코드를 구현했습니다.

이것저것 다 넣어서 해봤지만 반례를 찾지 못하고있습니다 ㅜ

 

http://boj.kr/86a69d1d5ce647b09c5a121b0c9e5ea9

답변 1

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 호영님 ㅎㅎ

이부분이 틀렸습니다.

이렇게 분기로직을 하셔야 합니다.

    if (cnt == 1) {
        cout << original_ret + temp + ret << "\n";
    } else {
        cout << original_ret + ret << "\n";
    }

 

또한, 이부분은 이렇게 하면 쉽게 할 수 있습니다. string함수를 잘 이용하시면 됩니다.

    for(auto &it : mp) {
        ret += string(it.second / 2, it.first);
    }


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

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

감사합니다.

강사 큰돌 올림.


전호영님의 프로필 이미지
전호영
질문자

앗 홀수만 신경쓰느라 짝수를 안넣었군요 ㅜ

감사합니다.

전호영님의 프로필 이미지
전호영

작성한 질문수

질문하기