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

Рассортировать на четные и нечетные числа исходных векторов - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Про массивы. http://www.cyberforum.ru/cpp-beginners/thread408813.html
Пытался анализировать вместимость стандартных массивов в С++. в том числе и 2мерных. оказывается есть значительные ограничения. И при чем как то вот встретил такую вот странность. Когда объявляю например: unsigned long int Mass; //т.е. 1*10 в 7й степени. или short Mass2; //а тут может влезть 1*10 в 8й степени А там где long - 8я степень критична. Короче говоря, предполагаю...
C++ Passing 'double' for converting 1 of 'void' Здравствуйте! пишу метод Эйткина (для выч. мата)с графикой но выдает ошибки в коде. Помогите исправить! заранее спасибо! #include <stdio.h> #include <math.h> #include <graphics.h> #include <conio.h> double fnc(double x) { return sqrt(x); } http://www.cyberforum.ru/cpp-beginners/thread408811.html
C++ создание и работа со списками
разработать программу для создания и работы с двусвязным списком , состоящим из структур. Для работы со списком создать меню со следующими пунктами: 1. Создание списка. 2. Просмотр списка. 3. Добавление в список новой записи. 4. Корректировка списка. 5. Выход. Пункт «корректировка списка» выполнить согласно своему варианту задания. Структура содержит фамилию и 4 оценки. Удалить из...
Как установить FLTK C++
Помагите установить FLTK???? может есть видео учитель или что то в этом роде??
C++ Разработать алгоритм, вычисляющий перекаются ли две окружности. http://www.cyberforum.ru/cpp-beginners/thread408788.html
Разработать алгоритм, вычисляющий перекаются ли две окружности. Точки и окружности задать с помощью структур. Результат вывести на экран. Правила форума cyberforum.ru 2.3 Создавайте темы с осмысленными и понятными названиями - это серьезно повышает шансы, что на ваш вопрос ответят. 3.3 Запрещено создавать темы с бессмысленными названиями вроде "Помогите!", "Вопрос" и т.п.
C++ перегружаемые функции Есть задание для массивов типа int и double: 1. найти сумму положительных элементов массива 2. произведение элементов, находящихся между минимальным и максимальным по модулю значениями 3. и упорядочить массив по возрастанию... и всё бы ничего, да только при вызове функций для работы со значениями типа double, программа отказывается запускаться. Помогите, пожалуйста, решить проблему и по... подробнее

Показать сообщение отдельно
Mashhha
0 / 0 / 0
Регистрация: 30.05.2011
Сообщений: 21

Рассортировать на четные и нечетные числа исходных векторов - C++

16.12.2011, 12:19. Просмотров 488. Ответов 0
Метки (Все метки)

Пожалуйста помогите исправить ошибки, возможно большинство из них глупые, тк я только начинаю изучать С++. (Среда разработки Visual C++ 2005)
Разработать класс содержащий:
- компоненты данные
- методы:
а) конструктор по умолчанию
б) конструктор с параметрами
в) конструктор копирования
д) методы класса для работы с данными
Данные класса должны иметь атрибут private.
Задача 1.
Создать 2 объекта разработанного класса. Класс – динамический вектор (одномерный массив). В результате выполнения программы в первом объекте должны содержаться все четные, а во втором все нечетные числа исходных векторов. Содержимое объектов (их векторов) до и после обмена вывести на экран.
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
// задача 1
#include <iostream>
using namespace std;
 
class vector
{
public:
    vector(){         // конструктор по умолчанию?           
        _size = 0;
}  
    vector(vector &); // конструктор копирования
    ~vector(); 
 
int get(int index){
    return mass[index];
}
 
int size(){
return _size;   
}
 
void push_to_end(int a){
    mass[_size] = a;
_size++;    
}
 
void remove(int index){
    mass[index] = 0;
}
 
void show(){
int index;
for(index = 0; index < _size; index++){
printf("%d\n", mass[index]);
}
}
 
private:
    int mass[1000];
    int _size;
};
 
 
int main(){
 
int index; // можно ли его объявить еще раз если он объявлен в функции show?
vector v1;
vector v2;
 
v1.push_to_end(10);
v1.push_to_end(3);
v1.push_to_end(6);
v1.push_to_end(45);
v1.push_to_end(67);
v1.push_to_end(23);
 
v1.show();
 
for(index = 0; index < v1.size(); index++){         // четные
if(v1.get(index) % 2 = 0){
    v1.remove(index);
}
 
}
 
v1.show();
 
v2.push_to_end(1);
v2.push_to_end(3);
v2.push_to_end(6);
v2.push_to_end(5);
v2.push_to_end(11);
v2.push_to_end(2);
 
v2.show();
 
for(index = 0; index < v2.size(); index++){        // нечетные
if(v2.get(index) % 2 != 0){
    v2.remove(index);
}
}
 
 
v2.show();  
 
 
}
Задача 3.
Создать несколько объектов (например, а и b) разработанного класса. Класс – вектор (одномерный массив). Реализовать для объектов данного класса перегрузку операции + (с=а+b). Содержимое объектов (a,b,c, их векторов), до и после выполнения операции, вывести на экран.
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
// задача 3
#include <iostream>
using namespace std;
 
class cls{
public:
    cls(){         
        _size = 0;
    }
    cls(cls &); 
    cls(int i, int j){mass = i; _size = j} 
    ~cls(); 
    cls operator + (cls op2); //операнд ор1 передается неявно
    int get(int index){
        return mass[index];
    }
 
    int size(){ // для чего это?
        return _size;
    }
 
    void push_to_end(int a){ 
        mass[_size] = a;
        _size++;
    }
 
    void show(){
        int index;
        for(index = 0; index < _size; index++){
            printf("%d\n", mass[index]);
        }
    }
    
private:
    int mass[1000];
    int _size;
 
};
 
 cls::operator + (cls op2){
    cls temp;
    temp.a = a + op2.a
    temp.b = b + op2.b
 
    return temp; // возвращается новый объект, аргументы функций не изменяются
}
 
int main(){
    cls a;
    cls b;
    cls c;
 
    a.push_to_end(1);
    a.push_to_end(2);
    a.push_to_end(5);
    a.push_to_end(7);
    a.push_to_end(9);
 
    cout<<"Ishodnie znacheniia objecta a:\n";
    a.show();
 
    b.push_to_end(11);
    b.push_to_end(5);
    b.push_to_end(6);
    b.push_to_end(8);
    b.push_to_end(3);
 
    cout<<"Ishodnie znacheniia objecta b:\n";
    b.show();
    cout<<"\n";
 
    c = a + b; // сложение объектов а и b
    cout<<"Znacheniia objecta c posle c = a + b: \n";
    c.show();
    cout<<"\n";
    a.show();
    cout<<"\n";
    b.show();
 
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru