2 / 2 / 2
Регистрация: 23.03.2016
Сообщений: 142
1

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

12.09.2016, 11:58. Показов 2414. Ответов 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;
}
Что не так?
Миниатюры
Определить самое длинное и короткое слово  
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.09.2016, 11:58
Ответы с готовыми решениями:

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

Дан текст из нескольки строк, определить самое длинное и самое короткое слово
Вот задание: Дан текст из нескольки строк, определить самое длинное и самое короткое слово.... Я...

Ввести строку, содержащую несколько слов. Определить самое длинное и самое короткое слово
Здравствуйте, не могли бы мне помочь с кодом. Как его переписать, чтобы программа работала? ...

Определить самое длинное и короткое слово
Задача: Ввести строку, содержащую несколько слов. Определить самое длинное и самое короткое слово....

6
1172 / 833 / 359
Регистрация: 26.02.2015
Сообщений: 3,743
12.09.2016, 12:30 2
Во-первых, cin считывает до первого пробела в строке.
0
93 / 0 / 0
Регистрация: 29.10.2015
Сообщений: 15
12.09.2016, 12:31 3
cin>>str. Читает строку до пробела, воспользуй cin.getline(str,256); http://www.cplusplus.com/refer... m/getline/
0
1172 / 833 / 359
Регистрация: 26.02.2015
Сообщений: 3,743
12.09.2016, 12:33 4
Всё, не до конца понял алгоритм. Но пробельный символ не является гарантом того, что дальше или до было слово.
0
2 / 2 / 2
Регистрация: 23.03.2016
Сообщений: 142
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?
0
1172 / 833 / 359
Регистрация: 26.02.2015
Сообщений: 3,743
12.09.2016, 13:11 6
Цитата Сообщение от narsky Посмотреть сообщение
Т.е., после пробела может идти еще пробел, да? И как это исправить? С помощью while?
Да, Вы правы, это одна из ситуаций. Еще, например, когда после точки нет пробела и дальше начинается текст. Считать ли это словом "один.два"? :-) Это можно решить разными способами, например, с помощью логических флагов.
0
2 / 2 / 2
Регистрация: 23.03.2016
Сообщений: 142
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;
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
12.09.2016, 14:04
Помогаю со студенческими работами здесь

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

В заданном предложении найти самое короткое и самое длинное слово
Строка вводится с клавиатуры. Нужно выполнить задание, не применяя функций типа strtok и прочих,...

Поменять местами в предложении самое длинное и самое короткое слово
Сам код, но тут 12 ошибок выдает в логе: #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include...

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru