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

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

Войти
Регистрация
Восстановить пароль
 
narsky
2 / 2 / 1
Регистрация: 23.03.2016
Сообщений: 117
#1

Определить самое длинное и короткое слово - C++

12.09.2016, 11:58. Просмотров 254. Ответов 6
Метки нет (Все метки)

Задача:
Ввести строку, содержащую несколько слов. Определить самое длинное и самое корот-кое слово.
Код:
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 <iostream>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    char str[256], count[256], max[256], min[256];
    cout << "Введите строку: " << endl;
    cin >> str;
    int word = 0;
    int x;
    for (int i = 0; i != ' '; i++)
    {
        max[i] = str[i];
        min[i] = str[i];
    }
    for (int i = 0; i != '\0'; i++)
    {
        count[i] = str[i];
        if (count[i] = ' ')
        {
            word = word + 1;
            x = i + 1;
            if (strlen(count) >= strlen(max))
            {
                for (int j = 0, x; count[x] != ' '; x++, j++)
                    max[j] = count[x];
            }
            if (strlen(count) < strlen(min))
            {
                for (int j = 0, x; count[x] != ' '; x++, j++)
                    min[j] = count[x];
            }
        }
    }
    if (word == 0)
        cout << "Вы не ввели ни единого слова" << endl;
    cout << "Самое длинное слово: " << max << endl << "Самое короткое слово: " << min << endl;
    system("pause");
    return 0;
}
Что не так?
Миниатюры
Определить самое длинное и короткое слово  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.09.2016, 11:58
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Определить самое длинное и короткое слово (C++):

В заданной строке определить самое длинное и самое короткое слово - C++
Ввести несколько строк,каждая из которых содержит некоторое количество слов.В заданной строке определить самое длинное и самое короткое...

Дан текст из нескольки строк, определить самое длинное и самое короткое слово - C++
Вот задание: Дан текст из нескольки строк, определить самое длинное и самое короткое слово.... Я смог решить тока для одной...

Ввести строку, содержащую несколько слов. Определить самое длинное и самое короткое слово - C++
Здравствуйте, не могли бы мне помочь с кодом. Как его переписать, чтобы программа работала? #include &lt;iostream&gt; #include &lt;cstdlib&gt; ...

Определить самое длинное и короткое слово - C++
Задача: Ввести строку, содержащую несколько слов. Определить самое длинное и самое короткое слово. Код: #include &lt;iostream&gt; using...

Поменять местами самое длинное слово и самое короткое слово в тексте - C++
Пусть есть двумерный массив, заполненный символами. Рассматривать его как многострочный текст, слова в котором разделены одним или...

Найдите самое длинное, и самое короткое слово в заданном предложении - C++
Найдите самое длинное и самое короткое слово в заданном предложении.

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Nishen
342 / 180 / 68
Регистрация: 26.02.2015
Сообщений: 892
12.09.2016, 12:30 #2
Во-первых, cin считывает до первого пробела в строке.
p0jit0h
93 / 0 / 0
Регистрация: 29.10.2015
Сообщений: 15
12.09.2016, 12:31 #3
cin>>str. Читает строку до пробела, воспользуй cin.getline(str,256); http://www.cplusplus.com/reference/i...tream/getline/
Nishen
342 / 180 / 68
Регистрация: 26.02.2015
Сообщений: 892
12.09.2016, 12:33 #4
Всё, не до конца понял алгоритм. Но пробельный символ не является гарантом того, что дальше или до было слово.
narsky
2 / 2 / 1
Регистрация: 23.03.2016
Сообщений: 117
12.09.2016, 12:44  [ТС] #5
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 <iostream>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    char str[256], count[256], max[256], min[256];
    cout << "Введите строку: " << endl;
    cin.getline(str, 256);
    int word = 0;
    int x;
    for (int i = 0; str[i] != ' '; i++)
    {
        max[i] = str[i];
        min[i] = str[i];
    }
    for (int i = 0; str[i] != '\0'; i++)
    {
        count[i] = str[i];
        if (count[i] = ' ')
        {
            word = word + 1;
            x = i + 1;
            if (strlen(count) > strlen(max))
            {
                for (int j = 0, x; count[x] != ' '; x++, j++)
                    max[j] = count[x];
            }
            if (strlen(count) < strlen(min))
            {
                for (int j = 0, x; count[x] != ' '; x++, j++)
                    min[j] = count[x];
            }
        }
    }
    if (word == 0)
        cout << "Вы не ввели ни единого слова" << endl;
    cout << "Самое длинное слово: " << max << endl << "Самое короткое слово: " << min << endl;
    system("pause");
    return 0;
}
Цитата Сообщение от Nishen Посмотреть сообщение
Но пробельный символ не является гарантом того, что дальше или до было слово.
Т.е., после пробела может идти еще пробел, да? И как это исправить? С помощью while?
Nishen
342 / 180 / 68
Регистрация: 26.02.2015
Сообщений: 892
12.09.2016, 13:11 #6
Цитата Сообщение от narsky Посмотреть сообщение
Т.е., после пробела может идти еще пробел, да? И как это исправить? С помощью while?
Да, Вы правы, это одна из ситуаций. Еще, например, когда после точки нет пробела и дальше начинается текст. Считать ли это словом "один.два"? :-) Это можно решить разными способами, например, с помощью логических флагов.
narsky
2 / 2 / 1
Регистрация: 23.03.2016
Сообщений: 117
12.09.2016, 14:04  [ТС] #7
Nishen, Посмотрите, что не так.
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
#include <iostream>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    char str[256], count[256], max[256], min[256];
    cout << "Введите строку: " << endl;
    cin.getline(str, 256);
    int word = 0;
    for (int i = 0; str[i] != ' '; i++)
    {
        max[i] = str[i];
        min[i] = str[i];
    }
    for (int i = 0, j = 0; str[i] != '\0'; i++)
    {
        while (str[i] != ' ')
        {
            count[j] = str[i];
            j++;
            goto MM;
        }
        word = 1;
        j = 0;
        if (strlen(count) > strlen(max))
        {
            for (int j = 0; count[j] != '/0'; j++)
                max[j] = count[j];
        }
        if (strlen(count) < strlen(min))
        {
            for (int j = 0; count[j] != '/0'; j++)
                min[j] = count[j];
        }
        MM:;
 
    }
    if (word == 0)
        cout << "Вы не ввели ни единого слова" << endl;
    cout << "Самое длинное слово: " << max << endl << "Самое короткое слово: " << min << endl;
    system("pause");
    return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.09.2016, 14:04
Привет! Вот еще темы с ответами:

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

Заменить самое длинное слово на самое короткое и наоборот - C++
Необходимо заменить самое длинное слово на самое короткое и самое короткое на самое длинное. Я их нашел, но как заменить не знаю......

Напечатать самое длинное и самое короткое слово в строке - C++
Напечатать самое длинное и самое короткое слово в строке в С++

Найти самое длинное и самое короткое слово в тексте - C++
найти самое длинное и самое короткое слово в тексте #include &quot;stdafx.h&quot;endl; #include &lt;iostream&gt; #include &lt;string&gt; #include...


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

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

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