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

Строки (Найти длину самого короткого и самого длинного слова, а также сами эти слова)

08.12.2012, 16:11. Показов 3891. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Люди, подскажите, плиз, как написать програмку в с++ за условием, что дана строка, состоящая из слов, разделенных пробелами (одним или несколькими). Найти длину самого короткого и самого длинного слова, а также сами эти слова.
Помогите, чем можите, спасибо огромное.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.12.2012, 16:11
Ответы с готовыми решениями:

Найти длину самого короткого и самого длинного слова, а также сами эти слова
Народ, помогите, пожалуйста, как мне написать код в с++ програмки, в которой дана строка, состоящая из слов, разделенных пробелами (одним...

Найти длину самого короткого слова и самого длинного слова в строке
помогите!!! Дана строка, содержащая текст. Найти длину самого короткого слова и самого длинного слова.

Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова.
помогите написать программу =) очень нужно=) Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова.

9
146 / 146 / 32
Регистрация: 26.10.2008
Сообщений: 782
08.12.2012, 17:08
Стандартная функция strtok. Ваша задача решается небольшой модификацией примера из MSDN.
0
387 / 151 / 16
Регистрация: 12.05.2011
Сообщений: 450
08.12.2012, 19:28
лажу написал
0
0 / 0 / 0
Регистрация: 19.10.2012
Сообщений: 144
08.12.2012, 19:33  [ТС]
Цитата Сообщение от yekka Посмотреть сообщение
yekka@ENIAC:~/tmp [0] $ g++ minmax.cxx -std=c++11 -lboost_regex -o minmax yekka@ENIAC:~/tmp [0] $ ./minmax Исходная строка: Just do it! min: do max: Just yekka@ENIAC:~/tmp [0] $ ./minmax Исходная строка: Мама мыла раму. min: Мама max: Мама yekka@ENIAC:~/tmp [0] $ ./minmax Исходная строка: Дефрагментатор ntfs под linux. min: ntfs max: Дефрагментатор yekka@ENIAC:~/tmp [0] $
Что это ??? И почему
C++
1
#include <boost/regex.hpp>
не хочет открывать???
0
387 / 151 / 16
Регистрация: 12.05.2011
Сообщений: 450
08.12.2012, 19:56
поправил багу, теперь вот так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <string>
#include <iostream>
#include <boost/regex.hpp>
 
int main() {
    std::setlocale(LC_ALL, "en_US.UTF-8");
    std::wstring min, max, original;
    std::wcout << L"Исходная строка: ";
    std::getline(std::wcin, original);
 
    const wchar_t * expr = L"[a-zA-Zа-яA-Я]+";
    boost::wregex rexp(expr);
    boost::wsregex_iterator begin(original.begin(), original.end(), rexp), end;
    std::for_each(begin, end, 
            [&](const boost::match_results<std::wstring::const_iterator> & sm) {
                    if (min.length() > sm[0].length()) min = sm[0];
                    if (min.length() == 0)             min = sm[0];
                    if (max.length() < sm[0].length()) max = sm[0];
            });
    std::wcout << "min: " << min << std::endl;
    std::wcout << "max: " << max << std::endl;
}
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ g++ minmax.cxx -std=c++11 -lboost_regex -o minmax
 
$ ./minmax
Исходная строка: Just do it!
min: do
max: Just
 
$ ./minmax
Исходная строка: Мама мыла раму.
min: Мама
max: Мама
 
$ g++ minmax.cxx -std=c++11 -lboost_regex -o minmax
Исходная строка: Дефрагментатор ntfs под linux.
min: под
max: Дефрагментатор
2
What a waste!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
08.12.2012, 20:30
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
#include <iostream>
#include <sstream>
#include <iterator>
#include <algorithm>
#include <string>
#include <vector>
 
 
int main() {
   std::string const str = "If ranges are to be a feature of the language "
         "then they should probably be supported at language level "
         "rather than by some trick";
 
   std::istringstream iss(str);
   std::vector<std::string> words(
         (std::istream_iterator<std::string>(iss))
        , std::istream_iterator<std::string>());
   auto minmax = std::minmax_element(
          words.begin()
        , words.end()
        , [] (std::string const& lhs, std::string const& rhs) {
             return lhs.length() < rhs.length();
          });
 
   std::cout << "Word with minimum length (" << minmax.first->length()
         << "): " << *minmax.first << std::endl;
   std::cout << "Word with maximum length (" << minmax.second->length()
         << "): " << *minmax.second << std::endl;
}
http://ideone.com/a4We3n
1
387 / 151 / 16
Регистрация: 12.05.2011
Сообщений: 450
08.12.2012, 20:36
gray_fox, http://ideone.com/rtCQen
неправильно определено самое короткое слово (ntfs вместо под) и неправильно самое длинное (хотя здесь, конечно, зависит от определения слова)
1
What a waste!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
08.12.2012, 21:56
yekka, как-нибудь так тогда:
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 <algorithm>
#include <string>
#include <vector>
 
#include <boost/algorithm/string/trim.hpp>
#include <boost/algorithm/string/split.hpp>
 
 
int main() {
   std::wstring str = L"Дефрагментатор ntfs под linux,,,,,,,,,,,,,,,,,,,,,,,,,";
 
   boost::trim_if(str, boost::is_any_of(L" .,!?:;\"'()"));
   std::vector<std::wstring> words;
   boost::split(words, str, boost::is_any_of(L" .,!?:;\"'()"), boost::token_compress_on);
   auto minmax = std::minmax_element(
          words.begin()
        , words.end()
        , [] (std::wstring const& lhs, std::wstring const& rhs) {
             return lhs.length() < rhs.length();
          });
 
   std::wcout << L"Word with minimum length (" << minmax.first->length()
         << L"): " << *minmax.first << std::endl;
   std::wcout << L"Word with maximum length (" << minmax.second->length()
         << L"): " << *minmax.second << std::endl;
}
Цитата Сообщение от yekka Посмотреть сообщение
неправильно самое длинное
Ну в задании - разделено пробелами, делал попроще)
Цитата Сообщение от yekka Посмотреть сообщение
неправильно определено самое короткое слово
char и русские символы, да.
1
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
08.12.2012, 22:19
yekka, а почему бы не юзать <regex>, если юзаете
Цитата Сообщение от yekka Посмотреть сообщение
-std=c++11
Добавлено через 1 минуту
Цитата Сообщение от Romantikkk Посмотреть сообщение
не хочет открывать???
а библиотека буст есть?
0
387 / 151 / 16
Регистрация: 12.05.2011
Сообщений: 450
08.12.2012, 22:20
go, в gcc-4.7 не реализовано пока
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.12.2012, 22:20
Помогаю со студенческими работами здесь

Дана строка, содержащая текст. Найти длину самого короткого и самого длинного слова.
1. Дана строка, содержащая текст. Найти длину самого короткого и самого длинного слова. 2. 14.14. Имеется строка, содержащая буквы...

Найти длину самого длинного и самого короткого слова
Дана символьная строка, заканчивается точкой. Найти длину самого длинного и самого короткого слова не могу допереть как это...

Найти длину самого длинного и самого короткого слова
Дана строка символов. Найти длину самого длинного и самого короткого символа. Написать задачу с обращением к процедуре...

Найти длину самого короткого и самого длинного слова.
Дана строка, содержащая текст. Найти длину самого короткого и самого длинного слова.

Найти длину самого короткого и самого длинного слова
помогите решить Дана символьная строка, содержащая текст, который заканчивается точ¬кой. Найти длину самого короткого и самого длинного...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru