С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
HenryDukart
123 / 123 / 35
Регистрация: 05.10.2013
Сообщений: 457
Завершенные тесты: 2
#1

Найти количество слов, не используя strtok (зацикливание) - C++

21.11.2013, 22:10. Просмотров 262. Ответов 2
Метки нет (Все метки)

В чем чуть: вводится строка чар. Словом считается последовательность латинских букв. Все остальное - разделители. Использовать строки чар. Запрещено использовать функцию стрток. Помогите, пожалуйста. Почему происходит зацикливание?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <cstdio>
#include <cstdlib>
#include <cstring>
int main()
{
    char bufStr[256], letters[]="QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm;";
    gets (bufStr);
     int last(0), first;
     int len=strlen(bufStr), num(0);
     while ((first=strcspn((bufStr+last),letters))<len)
     {
            first+=last;
            last=strspn((bufStr+first), letters);
            last+=first;
            num++;
     }
    printf ("There are %d words.\n", num);
    system ("pause");
    return 0;
Добавлено через 1 час 23 минуты
first - первый симол слова, last - первый разделитель после слова
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.11.2013, 22:10
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти количество слов, не используя strtok (зацикливание) (C++):

Разбить строку на массив слов используя strtok() - C++
Мне нужно разделить строку на массив слов используя функцию strtok(), но получается скопировать только первое слово. Подскажите пожалуйста,...

Использование STRTOK Разбить строку на слова, из слов составить список C++ Функция strtok - C++
Задача Дана строка слов с разделителями, в данном примере слова с пробелами Нужно, используя функцию strtok, сформировать из этих слов...

Найти количество одинаковых слов, используя методы string - C++
#include&lt;iostream&gt; #include&lt;string&gt; using namespace std; int main() { int g(0), m, k, n, l, r; string s, s1, w; int sum =...

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

Найти общее количество слов и количество слов на букву ''с'' - C++
Выдает ошибку, что kol неинициализироанная переменная #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;stdio.h&gt; #include &lt;locale&gt; ...

strtok только для слов - C++
Посоветуйте функцию похожую на strtok(), только что работает и со словами. Например: Есть strtok, работает так char str =...

2
Max Dark
шКодер самоучка
1852 / 1652 / 603
Регистрация: 09.10.2013
Сообщений: 3,678
Записей в блоге: 6
Завершенные тесты: 2
21.11.2013, 23:08 #2
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
#include <cstdio>
#include <cstdlib>
#include <cstring>
 
 
int find(const char* str,const char* chars,bool flag) {
    int position = 0;
    while(*str) {
        bool found=false;
        for(int i =0; chars[i]; ++i)
            if(*str == chars[i]) {
                found = true;
                break;
            }
        if(flag == found)
            break;
        position++;
        str++;
    }
    return position;
};
 
int main() {
    char bufStr[256],
        letters[]="QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm";
    int last(0), first(0);
    char* buf = bufStr;
    int num(0);
    scanf("%s", bufStr);
 
    while(*buf) {
        first = find(buf+last , letters, true);
        last  = find(buf+first, letters, false);
        if(last-first>0)
            num++;
        buf+=last;
    }
    printf ("There are %d words.\n", num);
    system ("pause");
    return 0;
}
0
Hrollo
34 / 34 / 6
Регистрация: 05.11.2013
Сообщений: 147
21.11.2013, 23:40 #3
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
#include <iostream>
#include <conio.h>
#include <cstring>
 
using namespace std;
 
int main()
{
    char str[100],*p,*p1=" .,!?";
    cout<<"Enter string:";
    cin.getline(str,100);
    int countWord=0;
    bool inword = false;
    for(int i(0); str[i]!='\0';i++)
    {
        if(isalpha(str[i]) && !(inword))
        {
            countWord++;
            inword =true;
        }
        if(!isalpha(str[i]))
            inword =false;
    }
    cout<<"In string "<<countWord<<" words"<<endl;
    _getch();
    return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.11.2013, 23:40
Привет! Вот еще темы с ответами:

Дана строка, состоящая из русских слов. Найти количество слов, которые содержат ровно три буквы «А» - C++
Дана строка, состоящая из русских слов, набранных заглавными буквами и разделенных пробелами (одним или несколькими). Найти количество...

Переменное количество аргументов в функции ( зацикливание ) - C++
Здравствуйте. Подскажите пожалуйста как правильно огранизировать доступ к каждому параметру. Заранее спасибо. Вот код: #include...

Найти количество слов в строке; найти самое длинное слово, заканчивающееся на заданную букву - C++
Дана строка текста, в которой слова разделены пробелами. Необходимо: - вычислить количество слов в строке; ...

Функция, получает строку слов и рзделителей, а на выходе имеет массив слов из строки и количество этих слов - C++
мне нужна функция, которая во входе получает строку слов и рзделителей (&quot; &quot;, &quot;,&quot;, &quot;.&quot;, &quot;_&quot;, &quot;&quot;&quot;), а на выходе имеет массив слов из строки...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

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