Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 17, средняя оценка - 4.71
ozzy_b
2 / 2 / 0
Регистрация: 02.10.2012
Сообщений: 169
#1

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

20.11.2012, 19:07. Просмотров 2519. Ответов 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
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти самое короткое и самое длинное слово в строке (C++):

Найти самое длинное и самое короткое слово в строке - C++
Вообщем, дано задание найти самое длинное и самое короткое слово в строке. Все хорошо работает, но, если мы зададим слова , отличающиеся...

Найти самое короткое и самое длинное слово в строке - C++
Введённый строке найти самое короткое и длинное слово.словом считается последовательность симболов,которое отделено пробелом или знаком...

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

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

Напечатать самое длинное и самое короткое слово в строке - C++
Прошу помочь с решением задачи. Задана строка, состоящая из символов. Символы объединяются в слова. Слова друг от друга отделяются...

Напечатать самое длинное и самое короткое слово в строке - C++
. Напечатать самое длинное и самое короткое слово в этой строке. Вроде все выводиться но преподаватель задал вопрос что если одинаковые...

5
zss
Модератор
Эксперт С++
6530 / 6092 / 2007
Регистрация: 18.12.2011
Сообщений: 15,844
Завершенные тесты: 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 / 0
Регистрация: 02.10.2012
Сообщений: 169
20.11.2012, 19:16  [ТС] #3
zss, а можна смысл текста в кратце переказать, а то гугл переводит очень плохо.
0
zss
Модератор
Эксперт С++
6530 / 6092 / 2007
Регистрация: 18.12.2011
Сообщений: 15,844
Завершенные тесты: 1
20.11.2012, 19:20 #4
X=strtok(x, " "); - возвратит первое слово.
while (X=strtok(NULL," ")); - извлекает в X очередное слово и если слова не закончились,
то цикл повторяется.
1
ozzy_b
2 / 2 / 0
Регистрация: 02.10.2012
Сообщений: 169
20.11.2012, 19:26  [ТС] #5
zss, то по сути "while (X=strtok(NULL," "))" перебирает каждое слово отдельно?
0
DiffEreD
1431 / 768 / 95
Регистрация: 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
Привет! Вот еще темы с ответами:

Найти самое длинное и самое короткое слово в тексте - C++
найти самое длинное и самое короткое слово в тексте #include &quot;stdafx.h&quot;endl; #include &lt;iostream&gt; #include &lt;string&gt; #include...

Найти самое длинное и самое короткое слово в предложении - C++
Составить и отладить программу, которая выполняет следующие действия. В заданном тексте из нескольких предложений найти самое длинное и...

Строки: найти самое короткое и самое длинное слово - C++
прошу спосите меня.... Дана строка текста, в которой слова разделены пробелами. Необходимо: - определить количество слов в строке; ...

Найти самое короткое и самое длинное слово C++ - C++
Нужно написать программу, которая будет находить самое короткое и самое длинное слово в строке используя тип char.


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

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

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