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

Распечатать длинное и короткое слово в строке при заданном условии

09.02.2014, 01:08. Показов 1464. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Заданная строка, состоящая из символов. Символы объединяются в слова. Слова
друг от друга отделяются одним или несколькими пробелами. В конце текста ставится
точка. Текст содержит не более 255 символов. Выполнить ввод строки, используя
функцию Gets (s) и обработку строки. Распечатать длинное и короткое слово в этой строке.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.02.2014, 01:08
Ответы с готовыми решениями:

Распечатать самое длинное слово (последнее) и самое короткое слово (первое)
Распечатать самое длинное слово (последнее) и самое короткое слово (первое).

Найти самое короткое и длинное слово в строке
Вот пытался написать: uses CRT; const rz=; var s,smax,smin:string; i,max,min,p,n:integer; A:array of string; begin ...

Найти самое длинное и короткое слово в строке
найти самое длинное и короткое слово в строке. что в нете нету не чего толкового

11
 Аватар для programina
2062 / 619 / 41
Регистрация: 23.10.2011
Сообщений: 4,468
Записей в блоге: 2
09.02.2014, 01:59
Использовать функцию gets - плохая идея. И что делать, если окажется, что два или более слов одинаковой длины?
0
130 / 15 / 6
Регистрация: 05.08.2013
Сообщений: 285
09.02.2014, 02:38

А вот тут нужно быть осторожнее, ибо для ф-и gets невозможно задать ограничение на
размер вводимой строки, по крайней мере, в пределах стандартной библиотеки

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
char anything[255];
puts("Enter anything:");
gets(anything);
//объявить переменные для хранения промежуточных слов
int size=sizeof(anything)/sizeof(char);//Размер массива==вроде так, это далеко не единственный способ, кстати, взял с этого форума [URL="https://www.cyberforum.ru/cpp-beginners/thread347758.html"]тут[/URL]
for (int j=0;j<size;j++) {
//от противного, если нет пробела - значит есть буквы
    if (strcmp(anything[j]," ")!=0) {
        //здесь записывать слова в переменые, можно использовать тип вектор для этих целей
    }
}
//посчитать длину каждой переменной со словами
//найти min и max, для вектора это будет несложно
//вывести
cout << "min = " << min << endl; 
cout << "\n max = " << max << endl;
Добавлено через 6 минут
Ну про точку забыл.
И про размер тоже не совсем уверен.
Может стоит сделать так
C++
1
char anything=new char[255];
Добавлено через 19 минут
Цитата Сообщение от programina Посмотреть сообщение
И что делать, если окажется, что два или более слов одинаковой длины?
Мне кажется, что прописать исключения, можно даже exception вызвать через throw, правда слишком сложно.
А так 3 варианта:
1)Все слова равны по знакам max == min
2)Не введено ни одного слова
3)Введено 1 слово
0
0 / 0 / 0
Регистрация: 08.02.2014
Сообщений: 7
09.02.2014, 14:27  [ТС]
Добавлено через 9 минут
Цитата Сообщение от programina Посмотреть сообщение
Использовать функцию gets - плохая идея. И что делать, если окажется, что два или более слов одинаковой длины?
Я знаю что это очень плохая идея, без ее я бы и сам сделал, а так запутался окончательно, но надо сделать именно через нее все, такова задача.

Добавлено через 1 минуту
fier

Спасибо за помощь, но не хватает конечно окончательного кода как все это реализовать!
0
130 / 15 / 6
Регистрация: 05.08.2013
Сообщений: 285
09.02.2014, 19:01
Попробую сегодня написать.
0
0 / 0 / 0
Регистрация: 08.02.2014
Сообщений: 7
10.02.2014, 18:34  [ТС]
Цитата Сообщение от fier Посмотреть сообщение
Попробую сегодня написать.
Был бы очень благодарен за помощь!!!!

Добавлено через 23 часа 14 минут
fier, ну что, не вышло ничего?
0
130 / 15 / 6
Регистрация: 05.08.2013
Сообщений: 285
10.02.2014, 21:09
В процессе. Времени было не много.
0
0 / 0 / 0
Регистрация: 08.02.2014
Сообщений: 7
10.02.2014, 21:16  [ТС]
fier, мне до четверга надо сделать, так что время есть, я думал же не поможет никто. Спасибо за помощь!!!
0
130 / 15 / 6
Регистрация: 05.08.2013
Сообщений: 285
12.02.2014, 03:37
Здравствуйте.
Поробуйте посмотреть вот это
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
#include <stdio>
#include <windows.h>
#include <iostream.h>
#include <vector.h>
#include <string.h>
int main() {
char anything[255];
char hello[255];//ТАКОЙ РАЗМЕР ДЛЯ ПРИВЕТСТВЕННОЙ СТРОКИ СЛУЧАЕН, МОЖНО ЗАРАНЕЕ ОПРЕДЕЛИТЬ
CharToOem("Введите с клавиатуры строку, разделитель - пробел или 2 пробела, максимальная длина 255 символов\n",hello);
cout<<hello;
gets(anything);
vector<string> words;//ЗДЕСЬ БУДЕМ ХРАНИТЬ ВСЕ ВВЕДЁННЫЕ СЛОВА
string trim,buff;//ПЕРЕМЕННАЯ БУФЕР, ДЛЯ ХРАНЕНИЯ ОДНОГО СЛОВА
int size=strlen(anything);//ДЛИНА ВВЕДЁННОЙ СТРОКИ, СОДЕРЖАЩЕЙ СЛОВА
for (int i=0;i<size;i++) {
    trim=anything[i];
    if (trim==" ") {
        words.push_back(buff);
        buff="";
        i++;
        trim=anything[i];
        if(trim==" ") {
            i++;
        }
    }
    //ЗАПИШЕМ СНАЧАЛА ВСЮ СТРОКУ В ВЕКТОР
    buff+=anything[i];
}
words.push_back(buff);//ЗДЕСЬ ЗАПИШЕМ ПОСЛЕДНЕЕ СЛОВО
//words.push_back(buff);
int min,max,mn,mx;
mn=0;mx=0;
min=words[0].size();
max=words[0].size();
for (int i=0;i<words.size();i++) {
    if(min>words[i].size()) {
        min=words[i].size();
        mn=i;
    }
    if(max<words[i].size()) {
        max=words[i].size();
        mx=i;
    }
}
char max_c[255];
char min_c[255];
char len[6];
CharToOem("Самое длинное слово:",max_c);
CharToOem("Самое короткое слово:",min_c);
CharToOem("Длина:",len);
cout<<max_c<<words[mx]<<endl;cout<<len<<words[mx].size()<<endl;
cout<<"\n";
cout<<min_c<<words[mn]<<endl;cout<<len<<words[mn].size()<<endl;
 
system("pause");
return 1;
}
Компилировал в bcc32 под win7 - работает.
Это не совсем готовое решение, да и не очень идеальное, но
разобравшись в нём можно доделать, как Вам надо.
Если будут вопросы -пишите.

Добавлено через 1 час 14 минут
Я не учитывал точку, как конец строки.
Если нужно автоматически завершать ввод после точки, то тут нужно пользоваться ф-ями winapi.
Также не рассмотрены случаи ввода одних пробелов или слов одинаковой длины.
Рассмотрен случай для одного или 2-х пробелов, но если вместо if поставить while и кое-что поменять, то
можно любое количество пробелов сделать разделителями слов.
Нет контроля максимальной длины строки, что может привести к ошибке, когда мы выйдем за границы 255 символов.
Причём если надо 255 символов, то надо объявлять 256, т.к. у массива char в конце автоматически ставится
0 -терминатор.
Для записи и сравнения использовал класс string у которого есть много интересных методов для обработки строк. Хотя можно только с char, тогда не будет смешения c и с++.
0
 Аватар для programina
2062 / 619 / 41
Регистрация: 23.10.2011
Сообщений: 4,468
Записей в блоге: 2
12.02.2014, 04:03
fier, а почему на 54-й строке ничего нет? )
0
130 / 15 / 6
Регистрация: 05.08.2013
Сообщений: 285
12.02.2014, 07:40
А я и не заметил
0
130 / 15 / 6
Регистрация: 05.08.2013
Сообщений: 285
13.02.2014, 15:18
Вот ещё один вариант, правда точку в конце всё-равно не учитывает, но пробелов между словами может быть любое количество, не превышающее длину char'a. Если все слова равны по длине, то max=min, если два max или min равны между собой, то вернёт первое из max, min.
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
/*ПРОГРАММА ДЛЯ ВЫЧИСЛЕНИЯ САМОГО ДЛИННОГО И САМОГО КОРОТКОГО СЛОВА ИЗ ВВЕДЁННОЙ СТРОКИ*/
#include <stdio>
#include <windows.h>
#include <iostream.h>
#include <vector.h>
#include <string.h>
int main() {
char anything[255];
char hello[255];//ТАКОЙ РАЗМЕР ДЛЯ ПРИВЕТСТВЕННОЙ СТРОКИ СЛУЧАЕН, МОЖНО ЗАРАНЕЕ ОПРЕДЕЛИТЬ
CharToOem("Введите с клавиатуры строку, разделитель - пробел или 2 пробела, максимальная длина 255 символов\n",hello);
cout<<hello;
gets(anything);
vector<string> words;//ЗДЕСЬ БУДЕМ ХРАНИТЬ ВСЕ ВВЕДЁННЫЕ СЛОВА
string trim,buff;//ПЕРЕМЕННАЯ БУФЕР, ДЛЯ ХРАНЕНИЯ ОДНОГО СЛОВА
int size=strlen(anything);//ДЛИНА ВВЕДЁННОЙ СТРОКИ, СОДЕРЖАЩЕЙ СЛОВА
for (int i=0;i<size;i++) {
    trim=anything[i];
    //ЕСЛИ ТЕКУЩЕЕ ЗНАЧЕНИЕ СИМВОЛА==ПРОБЕЛ И БУФЕР СЛОВА НЕ ПУСТ -
    if(trim==" "&&!buff.empty()) {
        words.push_back(buff);//ЗАПИШЕМ ВСЮ СТРОКУ В ВЕКТОР
        buff="";
    }
    //ЕСЛИ ТЕКУЩЕЕ ЗНАЧЕНИЕ СИМВОЛА==ПРОБЕЛ И БУФЕР СЛОВА ПУСТ - ПЕРЕМЕСТИМСЯ ВПЕРЁД НА 1 ИТЕРАЦИЮ
    if(trim==" "&&buff.empty()) {
        i++;//ВПЕРЁД НА 1 СТРОКУ
    }
    //А ЕСЛИ НЕТ - ЗАПИШЕМ ЭТОТ
    if(trim!=" ") {
        //ЗАПИШЕМ ВСЮ СТРОКУ В ВЕКТОР
        buff+=anything[i];  
    }
    
}
//words.push_back(buff);//ЗДЕСЬ ЗАПИШЕМ ПОСЛЕДНЕЕ СЛОВО
//words.push_back(buff);
int min,max,mn,mx;
mn=0;mx=0;
min=words[0].size();
max=words[0].size();
for (int i=0;i<words.size();i++) {
    if(min>words[i].size()) {
        min=words[i].size();
        mn=i;
    }
    if(max<words[i].size()) {
        max=words[i].size();
        mx=i;
    }
}
char max_c[255];
char min_c[255];
char len[6];
CharToOem("Самое длинное слово:",max_c);
CharToOem("Самое короткое слово:",min_c);
CharToOem("Длина:",len);
cout<<max_c<<words[mx]<<endl;cout<<len<<words[mx].size()<<endl;
cout<<"\n";
cout<<min_c<<words[mn]<<endl;cout<<len<<words[mn].size()<<endl;
system("pause");
return 1;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.02.2014, 15:18
Помогаю со студенческими работами здесь

Удалить в строке самое длинное/короткое слово
Я в программировании полный 0, но практические нужно делать, если не трудно , то люди добрые помогите пожалуйста 1) Ввести простое...

Распечатать самое длинное слово и самое короткое
Дана строка длиной не более 255 символов. Группы символов, разделенных между собой пробелом и не содержащих пробелов внутри себя, назовем...

В заданном предложении найти самое короткое и самое длинное слово
Делаю все строго по гайду, но после ввода строки вылетает &quot;exit code = 201&quot;. Пишу в free pascal'е. Эни айдиас? Program lab11; Uses ...

В заданном предложении найти самое короткое и самое длинное слово
1. Создать вектор М, содержащий количество отрицательных элементов каждого столбца матрицы z(3,4). 2. В заданном предложении найти...

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


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru