#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; } |
English