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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
user_p01
19 / 19 / 2
Регистрация: 03.11.2011
Сообщений: 80
#1

Не работает функция подсчета количеств букв "а" в словах - C++

24.09.2012, 15:03. Просмотров 493. Ответов 8
Метки нет (Все метки)

Подскажите пожалуйста почему не работает функция подсчета количеств букв "а" в словах. Ничего не выводит.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <string>
using namespace std;
int col_bukv(string s)
{
    int pos=0, col=0; 
    while (pos=s.find('а', pos)>=0)
        col++;
    return col;
}
int main()
{
    setlocale(LC_ALL, "rus");
    string s[10];
    int k=0, i;
    while (cin >> s[k])
        k++;
    for (i=0; i<k; i++)
      cout << col_bukv(s[i]) << '\t';
    cout << endl;
    system("pause");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.09.2012, 15:03
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Не работает функция подсчета количеств букв "а" в словах (C++):

В тех словах, которые окончиваются сочетанием букв "ть", заменить его окончание на "ил" - C++
дана строка. группы символов, разделенные пробелами и не содержащих пробелов внутри себя, называются словами. в тех словах, которые...

Упорядочить слова по возрастанию количеств букв "d", входящих в слова - C++
Помогите пожалуйста написать программу. Дана последовательность слов, разделенных пробелами, за последним словом - точка. Упорядочить слова...

Почему не работает функция std::regex_replace(temp,"amp;",""); - C++
Пробую вызывать функцию std::regex_replace(temp,&quot;amp;&quot;,&quot;&quot;); Пишет ошибку: test_ok_ruDlg.cpp 1&gt;d:\visual studio...

Удалять в словах, которые заканчиваются на букву "А" все другие буквы "А" - C++
Здравствуйте! Есть текст &quot;Варвара очень любит леопарда&quot;. Нужно сделать программу, которая будет удалять в словах, которые заканчиваются...

В зависимости от времени года "весна", "лето", "осень", "зима" определить погоду "тепло", "жарко", "холодно", "очень холодно" - C++
В зависимости от времени года &quot;весна&quot;, &quot;лето&quot;, &quot;осень&quot;, &quot;зима&quot; определить погоду &quot;тепло&quot;, &quot;жарко&quot;, &quot;холодно&quot;, &quot;очень холодно&quot;. Я так...

Заменить словах каждую букву "о" на "ма" - C++
Заменить словах каждую букву &quot;о&quot; на &quot;ма&quot;. Помогите найти ошибку. После того как ввожу строку выходит не пойми что. #include...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Invader_Zim
Twilight Parasite
153 / 149 / 2
Регистрация: 21.07.2011
Сообщений: 908
24.09.2012, 15:12 #2
user_p01, while (pos=s.find('а', pos)>=0)
посимвольно проверяй! а не так!
Andsteadur
153 / 137 / 3
Регистрация: 23.05.2009
Сообщений: 275
24.09.2012, 15:25 #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <string>
#include <algorithm>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "rus");
    string s[10];
    int k=0, i;
    while (cin >> s[k])
        k++;
    for (i=0; i<k; i++)
        cout << std::count(s[i].begin(), s[i].end(), 'a') << '\t';
    cout << endl;
    system("pause");
    return 0;
}
user_p01
19 / 19 / 2
Регистрация: 03.11.2011
Сообщений: 80
24.09.2012, 15:33  [ТС] #4
Спасибо. Но почему не работает мой код? Вроде по смыслу же все правильно. Как можно сделать без подключения <algorithm>?
DiffEreD
1430 / 767 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
24.09.2012, 15:49 #5
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
int col_bukv(const string & s)
{
    int col = 0;
    for (int i = 0; i<s.size(); i++)
    {
        if (s[i] == 'a') col++;
    }
    return col;
}
int main()
{
    SetConsoleCP (1251); SetConsoleOutputCP (1251);
    
    string str = "abracadabra";
    cout<<"Количество букв а: "<<col_bukv(str)<<endl;
    system("pause");
    return 0;
}
user_p01
19 / 19 / 2
Регистрация: 03.11.2011
Сообщений: 80
24.09.2012, 16:14  [ТС] #6
yuron_477, Спасибо. А как быть, если ввести строку так:
C++
1
2
3
int k=0;
while (cin >> s[k])
        k++;
или так:
C++
1
getline(cin, s);
Invader_Zim
Twilight Parasite
153 / 149 / 2
Регистрация: 21.07.2011
Сообщений: 908
24.09.2012, 16:20 #7
user_p01,
C++
1
2
string s;
cin>>s;
doctor_lecter
280 / 153 / 8
Регистрация: 22.09.2012
Сообщений: 283
24.09.2012, 16:22 #8
user_p01,
во-первых while (cin >> s[k]) так не надо делать, ввод нужно сделать внутри цикла, и еще нужно проверять что k меньше чем размер массива s.
Во-вторых, while (pos=s.find('а', pos)>=0) надо заменить на while ((pos=s.find('a', pos)) != string::npos)
Если в s нету символа a, то получается что find возвращает string::npos, равный по-моему LONG_MAX, который больше нуля (т.е s.find('а', pos)>=0 равно true), и это значение присваивается pos (получается pos = 1 и этот цикл выполняется бесконечно)
DiffEreD
1430 / 767 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
24.09.2012, 16:45 #9
user_p01, если вам так надо через while, то тогда так:
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
int col_bukv(const string & s)
{
    int col = 0;
    for (int i = 0; i<s.size(); i++)
    {
        if (s[i] == 'a') col++;
    }
    return col;
}
const int N = 6;
int main()
{
    SetConsoleCP (1251); SetConsoleOutputCP (1251);
    
    string s[N];
    int i = 0;
    cout<<"Вводите слова: ";
    while (cin>>s[i++] && i<N);
    for (i=0; i<N; i++)
        cout<<"Количество букв \"а\" в слове "<<s[i]<<": "<<col_bukv(s[i])<<endl;
    cout<<endl;
    system("pause");
    return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.09.2012, 16:45
Привет! Вот еще темы с ответами:

Заменить в словах окончания "ing" на "ed". - C++
Дана последовательность английских слов. В словах, которые оканчиваются сочетанием букв &quot;ing&quot;, заменить это окончание на &quot;ed&quot;. Помогите...

Из слова "яблоко" путем склеек и вырезок его букв получить слова "блок" и "око" - C++
Самым самым самым простым способом.

Подсчитать, сколько букв "Р", "к", "т" в данной строке - C++
дана строка подсчитать сколько в ней букв Р, к, т. помогите=)

Как работает функция "test" в приведенном коде - C++
Объясните как работает функция test #include &lt;conio.h&gt; #include &lt;iostream.h&gt; #include &lt;limits.h&gt; int test(long int a) ...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
24.09.2012, 16:45
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru