Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
ozzy_b
2 / 2 / 1
Регистрация: 02.10.2012
Сообщений: 169
1

Найти самое короткое и самое длинное слово в строке

20.11.2012, 19:07. Просмотров 2861. Ответов 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>
#include <string.h>
#include <conio.h>
#include <stdio.h>
using namespace std;
void inp(char[]);
void tok(char[], int);
int main()
{
 char x[100];
 
 inp(x);
 int size=strlen(x);
 tok(x, size);
 getch();
 return 0;
}
void inp(char x[])
{
    cout<<"Input string: ";
    gets(x);
    cout<<endl;
}
void tok(char x[], int size)
{
    char* max=NULL,* min=NULL;
    char *X;
    X=strtok(x, " ");
    min=X;
    max=X;
    do
    {
     if (strlen(X)<strlen(min))
      min=X;
     if (strlen(X)>strlen(max))
       max=X;
    }
    while (X=strtok(NULL," "));
    cout<<"Min: "<<min<<endl;
    cout<<"Max: "<<max<<endl;
}
Как здесь работает цикл(для чего здесь do), и что значит вот ето "while (X=strtok(NULL," "));"(что значит NULL)?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.11.2012, 19:07
Ответы с готовыми решениями:

Найти самое длинное и самое короткое слово в строке
Вообщем, дано задание найти самое длинное и самое короткое слово в строке. Все...

Найти самое короткое и самое длинное слово в строке
Посмотрите на код, что не так пишу? #include &lt;iostream&gt; #include &lt;string.h&gt; ...

Найти самое короткое и самое длинное слово в строке
Введённый строке найти самое короткое и длинное слово.словом считается...

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

Напечатать самое длинное и самое короткое слово в строке
Прошу помочь с решением задачи. Задана строка, состоящая из символов....

5
zss
Модератор
Эксперт С++
7376 / 6777 / 4290
Регистрация: 18.12.2011
Сообщений: 17,908
Завершенные тесты: 1
20.11.2012, 19:14 2
Не ленитесь заглядывать в help. Цитирую:
On the first call to strtok, the function skips leading delimiters and returns a pointer to the first token in strToken, terminating the token with a null character. More tokens can be broken out of the remainder of strToken by a series of calls to strtok. Each call to strtokmodifies strToken by inserting a null character after the token returned by that call. To read the next token from strToken, call strtok with a NULL value for the strToken argument. The NULL strToken argument causes strtok to search for the next token in the modified strToken. The strDelimit argument can take any value from one call to the next so that the set of delimiters may vary.
Т.е. первый раз функция возвращает первое слово. При последующих вызовах имя строки можно заменять нулем и будет возвращаться очередное слово.
1
ozzy_b
2 / 2 / 1
Регистрация: 02.10.2012
Сообщений: 169
20.11.2012, 19:16  [ТС] 3
zss, а можна смысл текста в кратце переказать, а то гугл переводит очень плохо.
0
zss
Модератор
Эксперт С++
7376 / 6777 / 4290
Регистрация: 18.12.2011
Сообщений: 17,908
Завершенные тесты: 1
20.11.2012, 19:20 4
X=strtok(x, " "); - возвратит первое слово.
while (X=strtok(NULL," ")); - извлекает в X очередное слово и если слова не закончились,
то цикл повторяется.
1
ozzy_b
2 / 2 / 1
Регистрация: 02.10.2012
Сообщений: 169
20.11.2012, 19:26  [ТС] 5
zss, то по сути "while (X=strtok(NULL," "))" перебирает каждое слово отдельно?
0
DiffEreD
1442 / 779 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
20.11.2012, 19:54 6
STL решение:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
#include <string>
#include <sstream>
#include <algorithm>
#include <iterator>
 
int main()
{
    setlocale (LC_ALL, "Russian");
    std::string s = "Найти самое короткое и самое длинное слово в строке";
    std::stringstream ss(s);
    auto minmax = std::minmax_element(std::istream_iterator<std::string>(ss),
        std::istream_iterator<std::string>(),
        [] (const std::string& s1, const std::string& s2){return s1.size()<s2.size();});
    std::cout<<"min: "<<*minmax.first<<"\nmax: "<<*minmax.second<<std::endl;
    system("pause");
    return 0;
}
0
20.11.2012, 19:54
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.11.2012, 19:54

Напечатать самое длинное и самое короткое слово в строке
. Напечатать самое длинное и самое короткое слово в этой строке. Вроде все...

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

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


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

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

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