Форум программистов, компьютерный форум CyberForum.ru

Разделение слов на слоги - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ рекурсивный алгоритм и использование точности "Эпсилон" http://www.cyberforum.ru/cpp-beginners/thread934266.html
Нихао всем) Тут такое дело. Нужно построить рекурсивный алгоритм, который бы возводил число "е" (экспоненту) в степень. Степень должна вводиться к клавиатуры. Но это не самое сложное: нужна еще точность "Эпсилон", которая тоже задается с клавиатуры. Допустим нужно вычислить "е^4", так мы "4" вводим с клавы, да еще и вводим точность, с которой будет выполняться возведение в степень (допустим с...
C++ Массив ссылок на функции Объясните где ошибка: #include <iostream> void minimum (int*,int); void maximum (int*,int); void average (int*,int); int main() { setlocale(LC_CTYPE, "rus"); // русский язык в консоли http://www.cyberforum.ru/cpp-beginners/thread934259.html
C++ Как напечатать содержимое окна windows forms?
Помогите, мне надо, чтобы после нажатия на кнопку печаталось окно Windows Forms. Как это можно сделать?
C++ НЕ записывается содержимое файла в переменную типа char
Нужно открыть файл, сохранить содержимое текста файла в переменную типа char под названием buffer и вывести переменную buffer на экран. При выводе этой переменной у меня отображается ноль, помогите исправить #include<iostream> #include<string.h> #include<fstream> using namespace std ; int main () { setlocale(0,"") ;
C++ Наследование наследование ) http://www.cyberforum.ru/cpp-beginners/thread934243.html
Доброе время суток всем! Делаю одно задание и столкнулся с вопросом У меня есть клас Person и клас avto со множивстом динамических и статический полей оба класса имеют перегруженные операторы ввод вывод ostream& operator<<(ostream& os, date& a) { if(a.day!=0){ os<<"birthday="; os<<a.day<<","; os<<a.mounth<<","; os<<a.year<<endl;
C++ Из условий задачи найти рекуррентную формулу Из условий задачи найти рекуррентную формулу. Используя найденную формулу решить поставленную задачу. подробнее

Показать сообщение отдельно
Stella
75 / 75 / 5
Регистрация: 26.02.2013
Сообщений: 224
06.08.2013, 16:07     Разделение слов на слоги
Попробуй так:
C++
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#include "stdafx.h"
#include <iostream>
#include <string>
#include <fstream>
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL,"Russian");
    /* Объявляем массив с гласными буквами */
    char glas [11];
    glas[0]='ё';
    glas[1]='у';
    glas[2]='е';
    glas[3]='ы';
    glas[4]='ы';
    glas[5]='а';
    glas[6]='о';
    glas[7]='э';
    glas[8]='я';
    glas[9]='и';
    glas[10]='ю';
    
    //считываем предложение.
    string predl;
    string buff;
    ifstream fin("e:\\text.in", ios::in);
    while(!fin.eof())
    { 
        getline(fin,buff);
        predl += buff;
    }
    fin.close();
    //считываем слово посимвольно
    
    char slovo [21];
    int nletter = 0;
    char probel =' '; 
    ofstream fout("e:\\text.out", ios::out);
    do 
    {
        int count=0;
        for(int j=0;j<=20;j++)
            slovo[j]=' ';   //избавляемся от мусора в массиве
        
        while(probel!=predl[nletter] && nletter < predl.size()-1 )// считывание слова
        {       
            slovo[count]=predl[nletter];
            count = count + 1;
            nletter = nletter + 1;
        }
        //ищем гласные и выводим в файл через дефисы слоги
        int pois = 0;
        int i;
        int flag=300;
 
        for(i=0;;i++)
        {
            fout << slovo[i];
            if (slovo[i]==probel) break;
            else 
            {
            for(pois=0; pois<=10; pois++)
                {
                if (slovo[i]==glas[pois])
                    if(slovo[i+1]==probel) break; //чтобы не ставить лишний дефис 
                    else
                    {
                        fout << "-";
                        pois=10;
                    }   
                }
            }
            
        }
        ++nletter;
    }while ( nletter < predl.size() );
    
    fout.close();
    
    return 0;
  }
там вся суть в том, что после последнего слова в predl пробела нет,
поэтому цикл
C++
1
2
3
4
5
while(probel!=predl[count])// считывание слова
        {       
            slovo[count]=predl[count];
            count=count+1;
        }
и вылетает.
 
Текущее время: 09:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru