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

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

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

Показать сообщение отдельно
fier
127 / 12 / 1
Регистрация: 05.08.2013
Сообщений: 222
12.02.2014, 03:37     Распечатать длинное и короткое слово в строке при заданном условии
Здравствуйте.
Поробуйте посмотреть вот это
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 и с++.
 
Текущее время: 22:07. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru