작성
·
66
0
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
안녕하세요 선생님.
입력받은 문자열을 map을 사용해 알파벳 당 개수로 저장했습니다.
홀수가 2개 이상이면 sorry를 출력하도록 했습니다.
홀수가 1개인 경우, 홀수 알파벳의 개수 -1 을 하고 , 홀수 알파벳을 저장했습니다.
그 후 다시 루프를 돌면서
각 알파벳 개수의 절반만큼 오름차순으로 문자열을 만들고,
미리 저장해둔 홀수 알파벳 1개를 더한 뒤 , 오름차순 문자열을 뒤집어서 더하는 방식으로 코드를 구현했습니다.
이것저것 다 넣어서 해봤지만 반례를 찾지 못하고있습니다 ㅜ
답변 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점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
앗 홀수만 신경쓰느라 짝수를 안넣었군요 ㅜ
감사합니다.