Задание
Разбить слово по слогам . Между слогами вставить тире.
Выбор алгоритма решения задачи
Для решения этой задачи, необходимо оценить условие разбивания по слогам. Потом по этим условиям разбить слово.
Описание решения задачи
Данную задачу можно развязать следующим способом: объявляем переменную и вносим у нее слово. Потом делаем цикл и считаем сколько там гласных в переменную s. Если 1, тогда мы не разбиваем, а сразу переходим на конец. Если гласных больше, чем одна, тогда входим в цикл. Проверяем условие данная буква гласная, или нет. Если гласная, тогда мы увеличиваем переменную sum на 1 и проверяем есть ли следующая буква первой или второй гласной буквой, если так, тогда мы ставим '-', если нет, то проверяем есть ли гласная третья, четвертая, пятая, если так, тогда переменная ind = 2, 3 или 4. В следующем цикле мы проверяем есть ли данная буква гласной, если нет, тогда проверяем ind = 2, 3 или 4 и сумма гласных не равняется сумме у цикла, то есть s != sum, если так, тогда ставим '-'.
Схема алгоритма решения задачи
Текст программы
1 Head.h
// razbivka po slogas
#ifndef TEXT_H
#define TEXT_H
// class pazbivka texta po slogam
class text {
public:
text ();
void setText ( char * );
void setProb (char *);
void printText ();
private:
char *slovo;
};
#endif
6.2 Prog.cpp
#include <iostream.h>
#include <conio.h>
#include "head.h"
int main ()
{
char *sPtr = "alexander";
text t;
cout << "Slovo : "<<sPtr<<"\n";
cout << "Razbitoe po slogam slovo: ";
t.setProb ( sPtr );
t.printText();
cout << endl;
getch();
return 0;
}
6.3 Func.cpp
#include <iostream.h>
#include "head.h"
text::text() { slovo = 0; }
void text::setText ( char *s ) {
slovo = s;
}
void text::setProb (char *text1) {
int s = 0, sum = 0, ind = 1;
for (int i=0; text1[i] != '\0'; i++)
if ((text1[i] == 'a') || (text1[i] == 'o') ||(text1[i] == 'u')||
(text1[i] == 'e') || (text1[i] == 'y') || (text1[i] == 'i'))
s++;
if (s == 1)
cout << text1;
if (s > 1) {
for (int i=0; text1[i] !='\0'; i++) {
cout << text1[i];
if ((text1[i] == 'a') || (text1[i] == 'o') ||(text1[i] == 'u')||
(text1[i] == 'e') || (text1[i] == 'y') || (text1[i] == 'i')) {
sum++;
if ((text1[i+1] == 'a') || (text1[i+1] == 'o') ||(text1[i+1] == 'u')||
(text1[i+1] == 'e') || (text1[i+1] == 'y') || (text1[i+1] == 'i'))
cout <<"-";
else if ((text1[i+2] == 'a') || (text1[i+2] == 'o') ||(text1[i+2] == 'u')||
(text1[i+2] == 'e') || (text1[i+2] == 'y') || (text1[i+2] == 'i'))
cout << "-";
else if ((text1[i+3] == 'a') || (text1[i+3] == 'o') ||(text1[i+3] == 'u')||
(text1[i+3] == 'e') || (text1[i+3] == 'y') || (text1[i+3] == 'i'))
ind = 2;
else if ((text1[i+4] == 'a') || (text1[i+4] == 'o') ||(text1[i+4] == 'u')||
(text1[i+4] == 'e') || (text1[i+4] == 'y') || (text1[i+4] == 'i'))
ind = 3;
else ind = 4;
}
else if ((ind == 2)|| (ind == 3) || (ind == 4)) {
if (s != sum) cout <<"-";
ind = 0;
}
}
}
}
void text::printText() {
cout << slovo;
}
Результати роботи програми
alexander
a-le-xan-der