이 문제에서는 크기가 N이고 정수 X인 문자열 str[]이 제공됩니다. 우리의 임무는 문자열에서 첫 번째 X 모음을 인쇄하는 프로그램을 만드는 것입니다. .
문자열에서 첫 번째 X 모음을 인쇄하고 X 모음보다 적은 경우 -1을 인쇄합니다.
문제를 이해하기 위해 예를 들어 보겠습니다.
Input: str = "learn C programming language", X = 5 Output: e, a, o, a, i Vowels are a, e, i, o, u
해결 방법
문제에 대한 간단한 해결책은 문자열 문자를 헌장으로 순회하는 것입니다. 그리고 문자열의 모든 모음을 모음 문자열에 저장합니다. 그리고 이 문자열의 길이가 X와 같으면 반환합니다. 문자열의 모든 모음이 X까지 셀 수 없으면 -1을 반환합니다.
예
솔루션 작동을 설명하는 프로그램
#include <iostream> #include <string.h> using namespace std; bool isaVowel(char c){ c = tolower(c); if (c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u') return true; return false; } string findXVowelsString(string s, int x){ string vowelsString = ""; for (int i = 0; i < s.length(); i++) { if (isaVowel(s[i])) vowelsString += s[i]; if (vowelsString.length() == x) { return vowelsString; } } return "-1"; } int main(){ string str = "learn C programming language"; int x = 5; cout<<"The first "<<x<<" vowels from the string are "<<findXVowelsString(str, x); return 0; }
출력
The first 5 vowels from the string are eaoai