С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

Поменять местами min и max - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ После максимального элемента списка L вставить заданный элемент a. http://www.cyberforum.ru/cpp-beginners/thread412756.html
После максимального элемента списка L вставить заданный элемент a. Добавлено через 4 часа 7 минут В книге Герберта Шилдта списков вообще найти не могу(
C++ умножение чисел систем счисления задание: Написать программу для выполнения арифметических операций в разных системах счисления. вариант: 13. Числа по основанию 8 и 4. Выполнить операцию умножения помогите пожалуйста http://www.cyberforum.ru/cpp-beginners/thread412751.html
Мультипликативные операций C++
Помогите написать программу. Нужно взять два любых числа и продеманстрировать мультипликативные операций.
Работа с файлами C++
Здравствуйте,помогите Написать программу, которая работает в одном из двух режимов. Если в те¬кущем каталоге имеется текстовый файл “tabl.txt”, то распечатать построчно его содержимое. В противном...
C++ Реализация стека с помощью массива http://www.cyberforum.ru/cpp-beginners/thread412736.html
Извиняюсь. Неправильно тему назвал :) Стек – KStack Методы: конструкторы, деструктор; операции: >>, <<, +, +=, =, ==, != функции: IsEmpty(), Size(), Clear() - удалить все элементы...
C++ Вывести цифры треугольником Помогите, пожалуйста:) Нужно вывести на экран: 1111111 222222 33333 4444 555 66 7 В C++ с использование цикла!:) подробнее

Показать сообщение отдельно
Альма
12 / 9 / 1
Регистрация: 25.11.2010
Сообщений: 358
Записей в блоге: 1

Поменять местами min и max - C++

20.12.2011, 18:44. Просмотров 514. Ответов 0
Метки (Все метки)

Вот задание:
Разработать класс содержащий:
- компоненты данные
- методы:
а) конструктор по умолчанию;
б) конструктор с параметрами;
в) конструктор копирования;
г) деструктор;
д) методы класса для работы с данными.
Данные класса должны иметь атрибут 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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include <iostream>
#include <windows.h>
using namespace std;
 
const n=5;
 
class array 
{ 
public: 
   array();   
   array(int); 
   array(const array &); 
   ~array();  
   void vvod(); 
   void print();
   int& maxel();
   int& minel();
private: 
   int imax,imin;
   int *mas;
}; 
array::array()
{
        mas=new int[n];
        if (mas) 
                cout<<"Massiv inicializirovan\n";
        else 
                cout<<"Ne hvataet pamyati\n";
}
array::~array()
{
        delete[] mas;
}
array::array(int)
{}
 
void array::vvod()
{       
    cout<<"\n\t Massiv " <<endl;
        for(int i=0; i<n; i++)                      
        {
                cout<<"\t a[ "<<i+1<<"]=";
        cin>>mas[i];
        }
}
 
void array::print() 
{ 
        for(int i=0; i<n; i++)                    
        {
             cout<<" "<<mas[i];
        }
} 
 
int& array::maxel()
{
    for(int i=0, ret=0; i<n; i++)
        {
                ret=mas[i]>mas[ret]?i:ret;
        }
        return mas[ret];
}
 
int& array::minel()
{
        for(int i=0, ret=0; i<n; i++)
        {
                ret=mas[i]<mas[ret]?i:ret;
        }
        return mas[ret];
}
 
void main() 
{ 
        array mas1; 
        array mas2;
        int m_max, m_min;
                
    mas1.vvod();
        mas2.vvod();
 
        cout<<"Ishodnye dannye: "<<endl;
        mas1.print();
        cout<<endl;
        mas2.print();
 
    int& max1=mas1.maxel();
    int& max2=mas2.maxel();
 
    int& min1=mas1.minel();
    int& min2=mas2.minel();
 
        if (max1>max2)
        {
                m_max=max1;
        }
        else
        {
                m_max=max2;
        }
 
                if (min1<min2)
        {
                m_min=min1;
        }
        else
        {
                m_min=min2;
        }
 
    int cnt=m_min;
        m_min=m_max;
        m_max=cnt; 
 
        cout<<"\nResult: "<<endl;
        mas1.print();
        cout<<endl;
        mas2.print();
}

Вот код...он все меняет...находит в двух минимальный и максимальны и меняет...а результат с измененными элементами не выводит, выводит исходные масиивы...как сделать, чтоб выводил уже с измененными??
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.