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

Массив с++ (удаление простых чисел) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вычислить количество цифр в заданной строке http://www.cyberforum.ru/cpp-beginners/thread135325.html
Добрий день товарищи!!! Помогите написать програму... Написать программу, которая вычисляет количество цифр в заданной строке.
C++ с++ цикли Помогите решить зачаски буду очень благодарен я уверен есть ище добрие люди( Задача 3. Найти первых 10 натуральных чисел, нацело делятся на 19 и находятся в интервале, левая граница которого 100.... http://www.cyberforum.ru/cpp-beginners/thread135304.html
Одномерные масивы C++
Приветик у меня проблемка помогите плиз решить прошку В одномерном массиве с четным количеством элементов (2N) находятся координаты N точек плоскости. Они располагаются в следующем порядке: x1,...
C++ Одномерные масивы
приветик помогите плиз решить прогу Разделить массив на две части, поместив в первую элементы, большие среднего арифметического их суммы, а во вторую — меньшие (части не сортировать).
C++ Одномерные масивы http://www.cyberforum.ru/cpp-beginners/thread135295.html
приветик помогите плиз решить прогу Дана последовательность п различных целых чисел. Найти сумму ее членов, расположенных между максимальным и минимальным значениями (в сумму включить и оба этих...
C++ Одномерные масивы Приветик помогите решить прошку пожалуста Даны целые положительные числа а1, а2,..., аn. Найти среди них те, которые являются квадратами некоторого числа т. подробнее

Показать сообщение отдельно
neske
1498 / 865 / 84
Регистрация: 26.03.2010
Сообщений: 2,966
25.05.2010, 18:51
Ах да, лишние действия у меня в коде, в функции test.
У NNN777 уже ближе к действительности, но можно еще проще:
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
#include <iostream>
#include <cmath>
#include <vector>
#include <algorithm>
#include <iterator>
 
bool test (int n)
{
    for (int i=2; i<=sqrt(n); i++)
        if (!(n%i)) return false;
    return true;
}
 
void show (std::vector <int> &v)
{
    std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " "));
    std::cout << std::endl;
}
 
 
int main ()
{
    const int size=20;
    std::vector <int> Z;
    std::vector <int> Y(size);
 
    srand(time(NULL));
    for (int i=0; i<size; i++)
        Z.push_back (rand()%20+1);
    std::cout << "Start matrix Z:\n";
    show (Z);
 
    reverse_copy (Z.begin(), Z.end(), Y.begin());
    std::cout << "Start matrix Y:\n";
    show (Y);
 
    std::vector<int>::iterator it;
    while ((it=std::find_if (Z.begin(), Z.end(), test)) != Z.end())
        Z.erase (it);
 
    std::cout << "Matrix Z after remove:\n";
    show (Z);
 
    int Z_min=*std::min_element (Z.begin(), Z.end());
    int Y_min=*std::min_element (Y.begin(), Y.end());
    int Z_max=*std::max_element (Z.begin(), Z.end());
    int Y_max=*std::max_element (Y.begin(), Y.end());
 
    if (Z_max > Y_max) std::cout << "Max_Z > Max_Y" << std::endl;
    else std::cout << "Max_Z < Max_Y" << std::endl;
    if (Z_min > Y_min) std::cout << "Min_Z > Min_Y" << std::endl;
    else std::cout << "Min_Z < Min_Y" << std::endl;
 
    system ("pause");
    return 0;
}
2
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru