#include <iostream> #include <string> #include <vector> using namespace std; char inline czy_samogloska( char const c ) { return ( c == 'a' ) || ( c == 'e' ) || ( c == 'i' ) || ( c == 'o' ) || ( c == 'u' ) || ( c == 'y' ) ? 1 : 0; } string wczytaj_dane() { string napis; napis.reserve( 200000 ); cin >> napis; for( int i = 0; i < napis.size(); ++i ) { napis[i] = czy_samogloska(napis[i]); } return napis; } long long wynikuj( string const& napis ) { long long wynik = 0; int zliczenie = 1; int idx_gt3_ogon = - 1; for( int i = 1; i < napis.size(); ++i ) { zliczenie = (napis[i] == napis[i - 1])? zliczenie + 1 : 1; //perr << "i = " << i << ", zliczenie " << zliczenie; int delta = 0; if( zliczenie > 2 ) { // i = 2; zliczenie = 3; delta = 1 // i = 3; zliczenie = 4; delta = 2 delta = i - 1; idx_gt3_ogon = i; } else if( idx_gt3_ogon != -1 ) { // ogon o indeksie 3, zakresy 0-2, 0-3, liczba zakresow 2 // ogon o indeksie 4, zakresy 0-2, 0-3, 0-4, liczba zakresow 3 delta = idx_gt3_ogon - 1; } wynik += delta; //perr << "Powiekszam wynik o " << delta << " do " << wynik; } return wynik; } int main() { string napis = wczytaj_dane(); long long wynik = wynikuj( napis ); cout << wynik << endl; return 0; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | #include <iostream> #include <string> #include <vector> using namespace std; char inline czy_samogloska( char const c ) { return ( c == 'a' ) || ( c == 'e' ) || ( c == 'i' ) || ( c == 'o' ) || ( c == 'u' ) || ( c == 'y' ) ? 1 : 0; } string wczytaj_dane() { string napis; napis.reserve( 200000 ); cin >> napis; for( int i = 0; i < napis.size(); ++i ) { napis[i] = czy_samogloska(napis[i]); } return napis; } long long wynikuj( string const& napis ) { long long wynik = 0; int zliczenie = 1; int idx_gt3_ogon = - 1; for( int i = 1; i < napis.size(); ++i ) { zliczenie = (napis[i] == napis[i - 1])? zliczenie + 1 : 1; //perr << "i = " << i << ", zliczenie " << zliczenie; int delta = 0; if( zliczenie > 2 ) { // i = 2; zliczenie = 3; delta = 1 // i = 3; zliczenie = 4; delta = 2 delta = i - 1; idx_gt3_ogon = i; } else if( idx_gt3_ogon != -1 ) { // ogon o indeksie 3, zakresy 0-2, 0-3, liczba zakresow 2 // ogon o indeksie 4, zakresy 0-2, 0-3, 0-4, liczba zakresow 3 delta = idx_gt3_ogon - 1; } wynik += delta; //perr << "Powiekszam wynik o " << delta << " do " << wynik; } return wynik; } int main() { string napis = wczytaj_dane(); long long wynik = wynikuj( napis ); cout << wynik << endl; return 0; } |