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

Посчитать и вывести количество непохожих слов в строке

24.11.2015, 21:33. Показов 987. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В общем проблема такова...
Нужно посчитать и вывести количество не похожих слов в строке. Никак не могу это написать
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.11.2015, 21:33
Ответы с готовыми решениями:

Посчитать и вывести количество непохожих слов в строке С++
Помогите написать программу очень срочно нужно! Вот что получилось и то не работает и только для подсчета похожих //...

Символьные массивы: посчитать количество слов в строке и вывести длину каждого слова
Помогите написать программу, условие такое: посчитайте количество слов в строке и выведите длину каждого слова. P.S. Первую часть -...

Посчитать и вывести на экран количество слов в файле, первую половину слов вывести в другой файл
3. Открыть файл, имя которого задается с клавиатуры. Посчитать и вывести на эк-ран количество слов в этом файле. Первую половину слов...

8
 Аватар для Erami
5 / 5 / 3
Регистрация: 23.10.2015
Сообщений: 35
24.11.2015, 21:37
Материал в помощь:
1)Узнать когда закончилось слово (код для англ. букв)
C++
1
if((str[i] >= 'a' && str[i] <= 'z') || (str[i] >= 'A' && str[i] <= 'Z'))]
2)Записать слово вектор строк и потом сравнивать.
С векторами знакомы/нет?
0
0 / 0 / 0
Регистрация: 24.11.2015
Сообщений: 8
24.11.2015, 21:41  [ТС]
не знаком с векторами
0
 Аватар для Erami
5 / 5 / 3
Регистрация: 23.10.2015
Сообщений: 35
24.11.2015, 21:46
Тогда двумерный массив.
C++
1
2
3
#define MAX_WORD_LENGHT 50
#define MAX_WORDS
char* words = new char[MAX+WORDS][MAX_WORD_LENGHT];
0
0 / 0 / 0
Регистрация: 24.11.2015
Сообщений: 8
24.11.2015, 21:54  [ТС]
мне нужен полный код) Буду признателен
0
 Аватар для Erami
5 / 5 / 3
Регистрация: 23.10.2015
Сообщений: 35
24.11.2015, 22:28
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
#include <iostream>
 
using namespace std;
 
// спрашивает и берёт строку у юзера
char* getstr(char* str, int size);
// принимает указатель на массив со строкой, его размер
// возвращает указатель на массив с введённой строкой
 
// собирает статистику по уникальности слов
int getwordstat(const char* str);
// принимает указатель на массив со строкой (только для чтения)
// возвращает кол-во уникальных слов
 
int main(){
    char* str = new char[1000]; // строка
    int unic; // кол-во уникальных слов
    getstr(str, 1000);
    unic = getwordstat(str);
    return 0;
}
 
char* getstr(char* str, int size){
    cout << "Enter string: " << endl << "-> ";
    cin.getline(str, size);
    return str;
}
 
int getwordstat(const char* str){
    char words[100][100]; // массив со словами
    int i; // счётчик
    int freewords = 0; //показатель свободного места(индекс) для слова в массиве
    char x; // буфер для копирования
    int wordstart = 0;
    int wordend = 0;
    bool word = false;
    for(i = 0; str[i] != '\0'; i++){ // выполнять до конца строки
        if((str[i] >= 'a' && str[i] <= 'z') || (str[i] >= 'A' && str[i] <= 'Z')){ // проверка буква ли это
            if(word == false){
                word = true; // настройка всего на новое слово
                wordstart = i;
                wordend = i;
            }
            else{
                wordend++; // увеличение длины слова на 1 символ
            }
        }
        else{
            word = false; // копирывание в новый массив и сброс настроек на слово
            int j;
            int k = wordend - wordstart;
            if(freewords >= 100){
                return -1; // error
            }
            for(j = 0; j != k; j++){
                words[freewords][j] = str[wordstart++];
            }
            freewords++;
            wordstart = 0;
            wordend = 0;
        }
    }
}
Осталось только дописать в последнюю функцию алгоритм сравнения, который есть самая лёгкая часть
0
0 / 0 / 0
Регистрация: 24.11.2015
Сообщений: 8
25.11.2015, 00:18  [ТС]
Erami, допиши пожалуйста до конца, а то я не понимаю что ты вообще имеешь ввиду
0
 Аватар для Erami
5 / 5 / 3
Регистрация: 23.10.2015
Сообщений: 35
25.11.2015, 16:09
Multipleer, У нас массивы чаров с одним словом. Сравнить их между собой и всё
0
0 / 0 / 0
Регистрация: 24.11.2015
Сообщений: 8
30.11.2015, 19:35  [ТС]
все равно я не знаю как это написать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.11.2015, 19:35
Помогаю со студенческими работами здесь

Посчитать количество слов в строке. Определить, что является разделителем слов
2) Ввести с клавиатуры строку. Посчитать количество слов в строке. Определить, что является разделителем слов. Вывести результаты на экран ...

В заданной строке посчитать количество слов. Разделителем слов считается один или несколько ответов
В заданной строке посчитать количество слов. Разделителем слов считается один или несколько ответов. Сделать с использованием компонента...

Посчитать количество слов в строке
Здравствуйте, я не знаю в чем дело, но прога всегда выдает что в строке 1 слово. #include &lt;iostream&gt; #include &lt;string.h&gt;...

Посчитать в строке количество слов
Посчитать в строке количество слов.

Посчитать количество слов в строке
Ввести строку и посчитать количество слов, БЕЗ встроенных функций. Вот, что получилось у меня, только не слова считает, а пробелы....


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru