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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вывести номер первой(последней) строки(столбца), содержащего равное количество положительных и отрицательных элементов http://www.cyberforum.ru/cpp-beginners/thread1092391.html
Здравствуйте! Дана целочисленная матрица размера 5 x 10. Вывести номер ее первый|последней строки|столбца, содержащего равное количество положительных и отрицательных элементов (нулевые элементы не...
C++ DjvuLibre и распаковка Всем доброй ночи. Такой вопрос, мне нужно поработать с djvuLibre . А именно расковырять djvuextract. Но открывая "решение" в папке win32 через VS12 происходит 21 ошибка компиляций из 21. Мне... http://www.cyberforum.ru/cpp-beginners/thread1092389.html
C++ Не выполняется условие!
Здравствуйте! подскажите пожалуйста по какой причине у меня может не выполняться условие проверки страны? void country(TEda * Start){ TEda * PNew; PNew=Start; while(PNew!=NULL){ ...
Разработать программу для определения объема оставшейся воды в теле, если оно полностью погружается в воду основанием вниз, а затем поднимается. C++
Есть олимпиадная задача. Помогите пожалуйста с алгоритмом если кто знает. Сплошное тело составлено из параллелепипедов с основанием 1 x 1, установленных на прямоугольное основание размером МхN....
C++ Разбить строку на слова http://www.cyberforum.ru/cpp-beginners/thread1092296.html
Разбить строку на слова. Все слова записать в отдельную строку. Помогите пожалуйста не получается. #include <iostream> #include <string> #include <cctype> #include <conio.h> using namespace std;...
C++ Связать векторы Доброго времени суток. У меня есть 4 класса: студент(id, имя, фамилия), факультет(id, название), занятия(id, название, тип), оценка(1-й термин, 2-й, 3-й, 4-й). Связаны наследованием так. ... подробнее

Показать сообщение отдельно
fier
127 / 12 / 2
Регистрация: 05.08.2013
Сообщений: 242
13.02.2014, 15:18
Вот ещё один вариант, правда точку в конце всё-равно не учитывает, но пробелов между словами может быть любое количество, не превышающее длину 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
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru