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

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

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

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

21.11.2013, 22:10. Просмотров 247. Ответов 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 - первый разделитель после слова
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.11.2013, 22:10     Найти количество слов, не используя strtok (зацикливание)
Посмотрите здесь:
C++ Разбить строку на массив слов используя strtok()
Использование STRTOK Разбить строку на слова, из слов составить список C++ Функция strtok C++
Найти количество одинаковых слов, используя методы string C++
Дан текст, найти количество слов и количество слов, у которых первый и последний символ совпадают C++
C++ Найти общее количество слов и количество слов на букву ''с''
strtok только для слов C++
C++ Дана строка, состоящая из русских слов. Найти количество слов, которые содержат ровно три буквы «А»
Переменное количество аргументов в функции ( зацикливание ) C++
C++ Найти количество слов в строке; найти самое длинное слово, заканчивающееся на заданную букву
C++ Функция, получает строку слов и рзделителей, а на выходе имеет массив слов из строки и количество этих слов
Строки.Найти количество слов? C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Max Dark
шКодер самоучка
1813 / 1614 / 588
Регистрация: 09.10.2013
Сообщений: 3,618
Записей в блоге: 6
Завершенные тесты: 2
21.11.2013, 23:08     Найти количество слов, не используя strtok (зацикливание) #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;
}
Hrollo
34 / 34 / 6
Регистрация: 05.11.2013
Сообщений: 147
21.11.2013, 23:40     Найти количество слов, не используя strtok (зацикливание) #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;
}
Ответ Создать тему
Опции темы

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