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

Строки. Вывести на экран все слова четной длины, у которых... - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Работа с функциями, возвращающими значения http://www.cyberforum.ru/cpp-beginners/thread1051646.html
Помогите , вот составил программу, но надо через ссылки,а я не могу.Вот условие: Найти значение выражения max(x,y,z)/max(x*x,y*y,z*z)+min(x,y,z)/min(x*x,y*y,z*z) Помогите пожалуйста(желательно попроще). Вот сама программа: #include <iostream> #include <stdio.h> #include <conio.h>
C++ Ошибка LNK2019 Всех с наступающим. Бьюсь на единственной ошибкой линковщика в коде. Сама ошибка похоже в перегрузке оператора умножения в шаблонном классе. Весь класс уже перекинул в хед-файл, но это не помогло. // 355.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h" #include "stdlib.h" #include <iostream> #include <fstream> http://www.cyberforum.ru/cpp-beginners/thread1051641.html
C++ Проверка объявления нескольких define
Как проверить, что объявлены оба этих дефайна? #define SOME_VAR1 100 #define SOME_VAR2_EXIST #ifdef SOME_VAR1 && SOME_VAR_EXIST //ошибка
C++ Массивы. Вставить значение a перед всеми элементами, кратными а
Вот условие задачи. Дан массив из N положительных элементов, больших 1 (2<=N<=100). Вставить значение a перед всеми элементами, кратными а Формат входных данных: На входе подаются в первой строке N - число элементов массива Вторая строка содержит число a Третья строка содержит N чисел - значения элементов массива Формат выходных данных: Выведите результирующий массив в строку
C++ Параметр shmget http://www.cyberforum.ru/cpp-beginners/thread1051615.html
У функции shmget три параметра. С первыми двумя всё понятно, а вот третий параметр мне не совсем понятен. Вот прототип ф-ии: shm_id shmget ( key_t key, /* ключ к сегменту */ int size, /* размер сегмента */ int shmflg ); /*флаг создания/использования */ У сервера(родтельского процесса) я указал shmget(key, SIZE, IPC_CREAT|0666); а какой флаг надо поставить у клиента (в дочернем...
C++ Вычисление функции,разложением ее в ряд Помогите, пожалуйста, в решении задачи. НИЧЕГО НЕ ПОЛУЧАЕТСЯ Написать программу нахождения суммы ряда с заданной точностью ε. Использовать рекуррентные соотношения при вычислении очередного члена ряда. Вычисление заканчивается, если модуль очередного слагаемого становится меньше заданного значения точности (ε), причем для этих рядов (при | x | < 1) абсолютная величина суммы всех... подробнее

Показать сообщение отдельно
MicM
 Аватар для MicM
820 / 487 / 90
Регистрация: 29.12.2009
Сообщений: 1,097
Завершенные тесты: 1
22.12.2013, 15:40     Строки. Вывести на экран все слова четной длины, у которых...
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
#include <iostream>
#include <string>
#include <cctype>
 
int main()
{
    std::string str = "kiju mama dfgfdh jmkmkj papa qwerty hji whow";
    std::string tmp,left,right;
    int i = 0;
    bool f = true,word = false;
    while (i<str.length())//в цикле идем по всей строке
    {
        if (isalpha(str[i]))//если очередной символ - буква,то
        {
            tmp.erase (0,tmp.size());//очищаем переменную для хранения слова
            while (i<str.length() && isalpha(str[i]))
            {
                tmp.append (1,str[i]);//формируем слово
                ++i;//увеличиваем счетчик
            }
            if (tmp.size()%2==0)//если кол-во символов в слове четно,то
            {
                f = true;//предположим, что левая и правая части состоят из одних и тех же букв
                left.erase (0,left.size());//очищаем переменные для хранения левой и правой частей слова
                right.erase (0,right.size());
                for (int j=0; j<tmp.size(); j++)//проходимся по полученному слову в tmp
                    if (j<tmp.size()/2)//если находимся в левой части слова,то
                        left.append (1,tmp[j]);//записываем в соответстувующую переменную
                    else right.append (1,tmp[j]);//иначе аналогично
                for (int j=0; j<left.size(); j++)//проходимся по левой части слова
                    if (right.find(left[j])==-1)//если какой-то буквы нет в правой части,то
                    {
                        f = false;
                        break;//выходим из цикла
                    }
            }
            if (f)//если левая и правая части состоят из одних и тех же букв
            {
                word = true;//фиксируем то,что такие слова есть
                std::cout <<tmp <<std::endl;//выводим слово
            }
        }
        else ++i;//иначе, если символ не буква, то идем дальше
    }
    if (!word)//если таких слов нет,то
        std::cout <<"No\n";//выводим "No"
    return 0;
}
 
Текущее время: 21:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru