이 문제에서는 문자열 str이 제공됩니다. 우리의 임무는 C++에서 두 번째로 자주 사용되는 문자를 찾는 프로그램을 만드는 것입니다. .
문제를 이해하기 위해 예를 들어보겠습니다.
입력
str = “abaacabcba”
출력
‘b’
솔루션 접근 방식
문자열에서 두 번째로 많은 문자를 찾습니다. 문자열에서 각 문자의 빈도를 저장하는 데 사용되는 카운트 배열 chatCount를 유지해야 합니다. 그런 다음 배열을 사용하여 배열에서 max 및 secondMax 빈도를 가진 문자를 찾습니다. 그리고 두 번째로 많이 나오는 문자를 표시합니다.
우리 솔루션의 작동을 설명하는 프로그램
예시
#include <iostream> #include <string.h> using namespace std; char findSecFreqChar(string str){ int charFreq[256] = {0}; for (int i = 0; i < str.length(); i++) (charFreq[str[i]])++; int maxFreq = charFreq[0], secFreq = charFreq[0]; for (int i = 0; i < 256; i++){ if (charFreq[i] > charFreq[maxFreq]){ secFreq = maxFreq; maxFreq = i; } else if (charFreq[i] > charFreq[secFreq] && charFreq[i] != charFreq[maxFreq]) secFreq = i; } return secFreq; } int main(){ string str = "tutorialspoint"; char secFreqChar = findSecFreqChar(str); cout << "Second most frequent character of the string is"<<secFreqChar; return 0; }
출력
Second most frequent character of the string is i