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

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

Войти
Регистрация
Восстановить пароль
 
Rusl@n_2014
0 / 0 / 0
Регистрация: 08.02.2014
Сообщений: 7
#1

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

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

Заданная строка, состоящая из символов. Символы объединяются в слова. Слова
друг от друга отделяются одним или несколькими пробелами. В конце текста ставится
точка. Текст содержит не более 255 символов. Выполнить ввод строки, используя
функцию Gets (s) и обработку строки. Распечатать длинное и короткое слово в этой строке.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.02.2014, 01:08
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Распечатать длинное и короткое слово в строке при заданном условии (C++):

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

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

Найти самое короткое и самое длинное слово в строке - C++
#include <iostream> #include <string.h> #include <conio.h> #include <stdio.h> using namespace std; void inp(char); void...

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

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

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

11
programina
1914 / 599 / 37
Регистрация: 23.10.2011
Сообщений: 4,468
Записей в блоге: 2
09.02.2014, 01:59 #2
Использовать функцию gets - плохая идея. И что делать, если окажется, что два или более слов одинаковой длины?
0
fier
127 / 12 / 2
Регистрация: 05.08.2013
Сообщений: 242
09.02.2014, 02:38 #3

А вот тут нужно быть осторожнее, ибо для ф-и 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="http://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
Rusl@n_2014
0 / 0 / 0
Регистрация: 08.02.2014
Сообщений: 7
09.02.2014, 14:27  [ТС] #4
Добавлено через 9 минут
Цитата Сообщение от programina Посмотреть сообщение
Использовать функцию gets - плохая идея. И что делать, если окажется, что два или более слов одинаковой длины?
Я знаю что это очень плохая идея, без ее я бы и сам сделал, а так запутался окончательно, но надо сделать именно через нее все, такова задача.

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

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

Добавлено через 23 часа 14 минут
fier, ну что, не вышло ничего?
0
fier
127 / 12 / 2
Регистрация: 05.08.2013
Сообщений: 242
10.02.2014, 21:09 #7
В процессе. Времени было не много.
0
Rusl@n_2014
0 / 0 / 0
Регистрация: 08.02.2014
Сообщений: 7
10.02.2014, 21:16  [ТС] #8
fier, мне до четверга надо сделать, так что время есть, я думал же не поможет никто. Спасибо за помощь!!!
0
fier
127 / 12 / 2
Регистрация: 05.08.2013
Сообщений: 242
12.02.2014, 03:37 #9
Здравствуйте.
Поробуйте посмотреть вот это
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
1914 / 599 / 37
Регистрация: 23.10.2011
Сообщений: 4,468
Записей в блоге: 2
12.02.2014, 04:03 #10
fier, а почему на 54-й строке ничего нет? )
0
fier
127 / 12 / 2
Регистрация: 05.08.2013
Сообщений: 242
12.02.2014, 07:40 #11
А я и не заметил
0
fier
127 / 12 / 2
Регистрация: 05.08.2013
Сообщений: 242
13.02.2014, 15:18 #12
Вот ещё один вариант, правда точку в конце всё-равно не учитывает, но пробелов между словами может быть любое количество, не превышающее длину 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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
13.02.2014, 15:18
Привет! Вот еще темы с ответами:

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

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

Короткое и длинное слово - C++
Найти в строке самое короткое и самое длинное слова. Не понимаю как тут делать...Напишите,пожалуйста, на языке С (не С++). Тут...

Определить самое длинное и короткое слово - C++
Задача: Ввести строку, содержащую несколько слов. Определить самое длинное и самое корот-кое слово. Код: #include &lt;iostream&gt; using...


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

Или воспользуйтесь поиском по форуму:
12
Yandex
Объявления
13.02.2014, 15:18
Ответ Создать тему
Опции темы

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