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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 30, средняя оценка - 4.87
Tatka_smile
0 / 0 / 0
Регистрация: 03.03.2011
Сообщений: 5
03.03.2011, 22:37     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #1
помогите написать программу =)
очень нужно=)
Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.03.2011, 22:37     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова.
Посмотрите здесь:

Дана строка, содержащая текст. Найти длину самого короткого и самого длинного слова. C++
C++ Найти длину самого короткого слова и самого длинного слова в строке
Найти длину самого короткого и самого длинного слова. C++
C++ Дана строка, содержащая текст. Найти длину самого короткого слова.
Строки (Найти длину самого короткого и самого длинного слова, а также сами эти слова) C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ma3a
Эксперт C++
612 / 456 / 31
Регистрация: 28.01.2011
Сообщений: 605
03.03.2011, 22:56     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #2
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
#include <iostream>
#include <string>
#include <algorithm>
#include <iterator>
#include <sstream>
#include <vector>
 
int main()
    {
    std::string line;
    std::getline(std::cin,line);
    std::istringstream strs(line);
    
    std::vector<std::string> words;
    std::copy(std::istream_iterator<std::string>(strs),
        std::istream_iterator<std::string>(),
        std::back_inserter<std::vector<std::string> >(words));
 
    std::string min_str = *words.begin(), max_str = *words.begin();
 
    for(std::vector<std::string>::iterator i = words.begin(); i != words.end(); ++i)
        {
        if(i->length() > max_str.length())
            max_str = *i;
        if(i->length() < min_str.length())
            min_str = *i;
        }
    std::cout << std::endl << "The longest word is \"" << max_str << "\"." << "Length is " << max_str.length() << std::endl;
    std::cout << "The shortest word is \"" << min_str << "\"." << "Length is " << min_str.length() << std::endl;
    }
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
03.03.2011, 23:07     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #3
Еще так можно
C++
1
2
3
4
5
6
7
8
std::string min_str = *std::min_element(words.begin(), words.end(), [](std::string &a, std::string &b) -> bool
{
   return a.length() < b.length();
}),
max_str = *std::max_element(words.begin(), words.end(), [](std::string &a, std::string &b) -> bool
{
   return a.length() < b.length();
});
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
03.03.2011, 23:32     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #4
asics, const лучше в подаче использовать все же. не суть конечно, но как-то более правильно по сути
asics
Freelance
Эксперт C++
 Аватар для asics
2838 / 1775 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
03.03.2011, 23:49     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #5
ForEveR, Ты имеешь ввиду тут
Цитата Сообщение от asics Посмотреть сообщение
C++
1
[](std::string &a, std::string &b) -> bool
?
MILAN
 Аватар для MILAN
883 / 777 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
04.03.2011, 00:12     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #6
Tatka_smile,
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
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <stdlib.h>
 
int main(void)
{
    char str[BUFSIZ];
    char buf[BUFSIZ];
    char *pword;
    int max,min;
    printf("Enter text -> ");
    gets(str);
    strcpy(buf,str);
    pword=strtok(buf," ,.");
    max=strlen(pword);
    min=strlen(pword);
    while(pword != 0)
    {
        if(strlen(pword)>max)
        {
            max=strlen(pword);
        }
        if(strlen(pword)<min)
        {
            min=strlen(pword);
        }
        pword=strtok(NULL," ,.");
    }
    pword=NULL;
    pword=strtok(str," ,.");
     while(pword != NULL)
     {
         if(strlen(pword)==max)
         {
             printf("\nLongest -> %s",pword);
         }
         if(strlen(pword)==min)
         {
             printf("\nShorting -> %s",pword);
         }
         pword=strtok(NULL," ,.");
     }
    getch();
    return 0;
}
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
04.03.2011, 10:54     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #7
asics, Да. Правильнее передавать const ссылку все же. Объект же не меняется в функции.
rangerx
1908 / 1517 / 139
Регистрация: 31.05.2009
Сообщений: 2,876
04.03.2011, 11:25     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #8
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
#include <iostream>
#include <sstream>
#include <string>
#include <iterator>
#include <functional>
#include <vector>
 
int main()
{
   using namespace std;
 
   cout << "Input string: ";
   string line;
   getline(cin, line);
 
   vector<string::size_type> v;
   istringstream iss(line);
 
   transform(istream_iterator<string>(iss), 
         istream_iterator<string>(),
         back_inserter(v),
         mem_fun_ref(&string::length));
 
   cout << "max: " << *max_element(v.begin(), v.end()) << '\n';
   cout << "min: " << *min_element(v.begin(), v.end()) << '\n';
   
   return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.03.2011, 23:59     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова.
Еще ссылки по теме:

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

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

Или воспользуйтесь поиском по форуму:
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
04.03.2011, 23:59     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. #9
Как вариант.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
#include <set>
#include <iterator>
#include <algorithm>
#include <functional>
#include <string>
 
struct cmp:public std::binary_function<std::string, std::string, bool>
{
    result_type operator () (const first_argument_type& one, const second_argument_type& sec)
    {
        return one.size() < sec.size();
    }
};
 
int main()
{
    std::multiset<std::string, cmp> ms((std::istream_iterator<std::string>(std::cin)), std::istream_iterator<std::string>());
    std::cout<<"Min is: "<< *ms.begin() <<" with size "<< ms.begin()->size() <<'\n';
    std::cout<<"Max is: "<< *(--ms.end()) <<" with size "<< (--ms.end())->size() <<'\n';
    return 0;
}
Yandex
Объявления
04.03.2011, 23:59     Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова.
Ответ Создать тему
Опции темы

Текущее время: 00:21. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru