С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/30: Рейтинг темы: голосов - 30, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 07.08.2012
Сообщений: 14

Подсчет количества слов начинающихся с гласных, согласных, иных букв

07.08.2012, 15:03. Показов 6131. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Начал изучать С++ и после очередной пройденной главы пытаюсь выполнить упражнение:
напишите прогу, которая читает слова по одному за раз, пока не будет введена отдельная буква 'q'. После прога сообщает сколько слов начинаются с гласных, сколько с согласных, а также кол-во слов не попадающие в эту категорию (цифры например). Пример запуска следующий:
Вводите слова (q - для выхода):
The 12 awesome oxen ambled
quietly arcoss 15 meters of lawn. q

5 слов начинаются с гласных.
4 слова начинаются с согласных.
2 остальных.
Вот мой текущий код, с некоторыми поправками в задании, тк я решил пока решить вопрос со словами, а потом решить выход из программы. Те выход из ввода текста я сделал введя '#'.
Помогите добавить:
- выход при введении отдельной буквы 'q'
- "разделять" слова, тк сейчас у меня программа считает каждую букву.

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
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    const int ArSize = 200;
    unsigned char ch[ArSize];
    int i = 0;
    cout << "Вводите слова. Для выхода введите #\n\n";
    for (i = 0; i < ArSize; i++)     //цикл для ввода строк. По другому, например через
    {                                      //cin.get() либо .getline() не работают. выглядит криво, но работает
        ch[i] = -76;                //это нужно, чтобы не выдавало ошибку (unsigned)(c+1) <=256
        cin >> ch[i];
        if (ch[i] == '#')
            break;
    }
    int Glas = 0, SoGlas = 0, Else = 0, flag = 0, count = 0;
    for (i = 0; i < ArSize; i++)
    {
        char word = ch[i];       //забыл для чего надо это, но и переписывать лень ;)
        if ((isalpha((unsigned char)word) || isdigit((unsigned char)word)) && flag == 0)
        {                               //(unsigned char)word нужен, чтобы не ругалось (unsigned)(c+1) <=256
            if (word >= 'a' && word <= 'z')                //можно изменить на isalpha()
            {                                                      //но мне так нагляднее
                if (word == 'a' || word == 'e' || word == 'y' || word == 'u' || word == 'i' || word == 'o')
                    Glas++;                 //подсчитывает гласные
                else
                    SoGlas++;              //согласные
            }
            else if (isdigit((unsigned char)word))
                Else++;                          //цифры
            //flag = 1;
        }
        //for ( ; count < ArSize && flag == 1; count++)         //закоментированный цикл - это
        //{                                                                     //я пробовал ставить флаги для отделения
        //  if (isspace((unsigned char)ch[count+1]))           //одних слов от других
        //      flag = 0;
        //  else if (isalpha((unsigned char)ch[count+1]) || isdigit((unsigned char)ch[count+1]))
        //      flag = 1;
        //}
    }
    cout << "Слов начинающихся с:\nГласных: " << Glas << endl           //собственно вывод всего
         << "Согласных: " << SoGlas << endl
         << "Иные: " << Else;
    
    float secs = 10;                                                           //выход после выполнения программы,                   
    clock_t delay = secs * CLOCKS_PER_SEC;                        //через 10 секунд
    clock_t start = clock();
    while (clock() - start < delay);
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.08.2012, 15:03
Ответы с готовыми решениями:

Подсчет слов в строке, начинающихся с гласных / согласных букв
Уважаемые форумчане, здравствуйте, помогите, пожалуйста новичку в С++ с кодом для подсчета слов в строке, начинающихся с гласных, согласных...

Подсчет количества гласных и согласных в предложении
#include &lt;iostream&gt; #include &lt;string&gt; using namespace std; int main() { string pred; int glas; int...

Подсчет количества слов, которые начинаются с гласных букв
Добрый день! Помогите, пожалуйста!!! Задали лабу по PHP. Задание: подсчитать количество слов в тексте, которые начинаются на гласные и...

8
 Аватар для Rexer
167 / 166 / 46
Регистрация: 10.10.2010
Сообщений: 725
07.08.2012, 16:06
вы попробуйте считывать cin,тогда у вас будет считываться до пробела,а это и есть слово.
считывайте в строку
а в выход можно сделать так,если считалась только буква q,то выйти из программы.
т.е если
C++
1
2
cin >> str;
if(strlen(str) == 1 && str[0] == 'q')
как-то так
0
0 / 0 / 0
Регистрация: 07.08.2012
Сообщений: 14
07.08.2012, 17:35  [ТС]
Цитата Сообщение от Rexer Посмотреть сообщение
вы попробуйте считывать cin,тогда у вас будет считываться до пробела,а это и есть слово.
считывайте в строку
а в выход можно сделать так,если считалась только буква q,то выйти из программы.
т.е если
C++
1
2
cin >> str;
if(strlen(str) == 1 && str[0] == 'q')
как-то так
Так я и говорю, тогда у меня не получается проходит по массиву и узнавать с гласной начинается слово или согласной, или это вообще цифра
Вы могли бы изменить уже имеющийся код, куда что добавить.
cin >> str вставить отдельно от цикла или в сам цикл?
0
 Аватар для Rexer
167 / 166 / 46
Регистрация: 10.10.2010
Сообщений: 725
07.08.2012, 21:01
Не заметил там у вас одного условия,простите
Тогда попробуйте на основе этого сделать свою программу.
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
#include <iostream>
#include <cstring>
using namespace std;
 
int main()
{
    char str[100];
    char *pch;
    int numbers = 0,
        others = 0;
 
    cin.getline(str,100);
    cout << endl << str;
    str[strlen(str) - 1] = '\0';
    pch = strtok(str," ,.!?");
    while(pch != NULL)
    {
        if(isdigit(pch[0]))
            numbers++;
        else
            others++;
        pch = strtok(NULL," ,.!?");
    }
    cout << endl << "Numbers:" << numbers << endl << "Others:" << others;
}
Вкратце что здесь я делаю - создаем строку str,для хранения ВСЕЙ введенной строки,дальше мы последний символ(а это будет q,ваш символ-выхода) затираем просто,ставя туда(вместо него) символ-окончания строки.
Дальше strtok-ом мы разбиваем строку на слова,символы-разделители используем такие,как написано,т.е ," ,.!?",после чего просто проверяем,если число - то увеличиваем количество чисел,если нет - то других,для гласных - согласных там не так долго переделать,просто проверяйте,чтобы pch[0] был гласной или согласной,как надо.
после чего pch указывает на другое слово наше(следующее) и так пока есть слова в предложении.
после чего выводим количество всего на экран.
Вот и все.
Пример работы
INPUT: Hello world i am the man q
Output: Numbers:0
Others: 6
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
07.08.2012, 23:11
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
#include <iostream>
 
bool in(char c, const char *symbols) {
  while (*symbols) if (c == *symbols++) return true;
  return false;
}
 
int main (int argc, char *argv[]) {
  std::string word;
  int vowelsCount = 0, consonantsCount = 0, othersCount = 0;
  const char vowels[] = "aeiouAEIOU";
  const char consonants[] = "qwrtypsdfghjklzxcvbnmQWRTYPSDFGHJKLZXCVBNM";
  std::cin >> word;
  while (word != "q") {
    if (in(word[0], vowels))
      vowelsCount++;
    else if (in(word[0], consonants))
      consonantsCount++;
    else
      othersCount++;
    std::cin >> word;
  }
  std::cout << "Vowels: " << vowelsCount << std::endl <<
    "Consonants: " << consonantsCount << std::endl <<
    "Others: " << othersCount << std::endl;
}
0
0 / 0 / 0
Регистрация: 07.08.2012
Сообщений: 14
08.08.2012, 17:32  [ТС]
Всем спасибо
И отдельное спасибо за идею с флагами. Ниже мой вариант:
PS код жутко индийский, так что извиняйте - только начал изучать
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
const int ArSize = 200;                                                                      
    char ch[ArSize];                                    
    char flags[ArSize];
    int i = 1;
    cout << "Вводите слова. Для выхода введите #\n\n";
    ch[0] = ' '; flags[0] = '-';
    for (i = 1; i < ArSize; i++)
    {
        flags[i] = '+';       //весь массив забиваю флагами +
        char letter;
        cin.get(letter);
        ch[i] = letter;
        if (ch[i] == 'q' && ch[i-1] == ' ')     //организую выход при вводе q
        {
            ch[i] = '\0';
            break;
        }
    }
    for (i = 1; i < ArSize; i++)          //здесь устанавливаю флаги начала слов
    {
        if ( (ch[i-1] == ' ') || (ch[i-1] == ',') || (ch[i-1] == '.') || (ch[i-1] == '\n') )
            flags[i] = '+';
        else
            flags[i] = '-';
    }
    int Glas = 0, SoGlas = 0, Else = 0;
    for (i = 1; i < ArSize; i++)
        if ((isalpha((unsigned char)ch[i]) || isdigit((unsigned char)ch[i])) && flags[i] == '+')
            {
                if (ch[i] >= 'a' && ch[i] <= 'z')
                {
                    if (ch[i] == 'a' || ch[i] == 'e' || ch[i] == 'y' || 
                        ch[i] == 'u' || ch[i] == 'i' || ch[i] == 'o')
                        Glas++;
                    else
                        SoGlas++;
                }
                else if (isdigit((unsigned char)ch[i]))
                    Else++;
            }
    cout << "Слов начинающихся с:\nГласных: " << Glas << endl
         << "Согласных: " << SoGlas << endl
         << "Иные: " << Else;
0
7 / 7 / 2
Регистрация: 18.02.2012
Сообщений: 61
12.07.2013, 22:44
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
#include <iostream>
#include <conio.h>
#include <cctype>
 
int main()
{
    using std::cin;
    using std::cout;
    int count_vow = 0;
    int count_cons = 0;
    int count_o = 0;
    char ch;
    cout << "Enter words (q to quit):\n";
    cin >> ch;
    while (ch != 'q') 
    {
    if (isalpha(ch))
         {
                 switch (ch)
                 {
                        case 'a' :
                        case 'A' : count_vow++;
                                   break;
                        case 'e' :
                        case 'E' : count_vow++;
                                   break;
                        case 'i' :
                        case 'I' : count_vow++;
                                   break;
                        case 'o' :
                        case 'O' : count_vow++;
                                   break;
                        case 'u' :
                        case 'U' : count_vow++;
                                   break;
                        default : count_cons++;
                 }
         }
          else  
               count_o++;
          cin >> ch;
    }
    cout << count_vow << " words beginning with vowels\n"
         << count_cons << " words beginning with consonants\n"
         << count_o << " others.";
         getch();
         return 0;
}
Что тут не так? Он должен подсчитывать кол-во слов, начинающихся с гласной, согласной и не попадающих и в одну из этих категорий.

Добавлено через 36 минут
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  switch (ch)
                 {
                        case 'a' :
                        case 'A' : 
                        case 'e' :
                        case 'E' : 
                        case 'i' :
                        case 'I' : 
                        case 'o' :
                        case 'O' :
                        case 'u' :
                        case 'U' : count_vow++;
                                   break;
                        default : count_cons++;
                 }
Упростил оператор с метками)) Та же проблема, в count_vow читает все слова, начинающиеся с букв, а в count_cons ваще ВСЕ))

Добавлено через 39 минут
Нужно написать программу, которая читает по одному слову за РАЗ, т.е. при вводе слова она анализирует с какой буквы оно начинается с гласной или согласной и увеличивает соответствующее значение счетчика, если программа читает цифры, либо другие символы отличные от букв программа должна увеличить другую переменную. При всем этом оно должно не просто 1 слово прочитать, а всю строку и каждое слово в нем(последовательность символом, разделенных пробельными символами) проанализировать таким образом. Все, что писали выше абсолютно неправильно.
0
8 / 5 / 3
Регистрация: 28.05.2014
Сообщений: 9
31.05.2014, 19:25
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
//6.7
#include <iostream>
#include <string>
 
int main()
{
    using namespace std;
    cout << "Enter words, (q to quit):\n";
    string word;
    int vowels = 0;
    int consonants = 0;
    int other = 0;
    while (cin >> word &&  word != "q")
    {
        if (isalpha(word[0]))
        {
            switch (word[0])
                {
                    case 'a': case 'A':
                    case 'e': case 'E':
                    case 'i': case 'I':
                    case 'y': case 'Y':
                    case 'o': case 'O':
                    case 'u': case 'U': vowels++;
                        break;
                    default: consonants++;
            }
        }else other++;
    }
    cout << vowels << " words beginning with vowels.\n";
    cout << consonants << " words beginning with consonants.\n";
    cout << other << " words beginning with any other character.\n";
 
    return 0;
}
0
0 / 0 / 0
Регистрация: 18.03.2015
Сообщений: 5
18.03.2015, 22: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
#include "stdafx.h"
#include<iostream>
#include<cctype>
#include<cstring>
using namespace std;
 
int main()
{
    char sym[30];
    char sym1[] = "q";
    cout << "Enter any words: ";
    int glas = 0;
    int soglas = 0;
    int others = 0;
    cin >> sym;
    while (strcmp(sym, sym1))
    {
        if (isalpha(sym[0]))
        {
            if (sym[0] == 'a' || sym[0] == 'A' || sym[0] == 'e' 
                || sym[0] == 'E' || sym[0] == 'y' || sym[0] == 'Y' 
                || sym[0] == 'u' || sym[0] == 'U' || sym[0] == 'i' 
                || sym[0] == 'I' || sym[0] == 'o' || sym[0] == 'O')
                glas++;
            else
                soglas++;
        }
        else
            others++;
        cin >> sym;
    };
 
 
    cout << "Number of words that begin with glas: " << glas << endl;
    cout << "Number of words that begin with soglas: " << soglas << endl;
    cout << "Number of words that begin with others: " << others;
    cin.get();
    cin.get();
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.03.2015, 22:07
Помогаю со студенческими работами здесь

Описать множества гласных и согласных букв русского языка, определить количество гласных и согласных букв в предложении
Описать множества гласных и согласных букв русского языка, определить количество гласных и согласных букв в предложении, введенном с...

Подсчет гласных и согласных букв
Здравствуйте уважаемые программисты. Задача состоит в том чтобы под считать гласные и согласные буквы. #include &lt;iostream&gt; ...

Подсчет количества гласных и согласных (исправить код)
Ребят, помоги исправить код. Код написан в классах, суть кода(подсчитывает количество гласных и согласных), но выдаёт ошибки...кто может...

Подсчет числа согласных и гласных букв
Дан текстовый файл с него считывается информация, необходимо посчитать сколько согласных и гласных букв. Помогите пожалуйста написать,...

Подсчет гласных и согласных букв в строке
Помогите пожалуйста. Нужно написать полностью программу(если не усложнит сильно дело, написать к каждому важному рядку объяснение): ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru