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

Дружественные классы - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 31, средняя оценка - 4.97
-Andriy-
0 / 0 / 0
Регистрация: 28.04.2010
Сообщений: 26
27.09.2010, 21:56     Дружественные классы #1
Помогите !!! Завтра надо сдавать а я ету тему совсем непонимаю...

Создайте класс Matrix для хранения матрицы целого типа. Создать конструктор, который позволяет объекту этого класса принимать начальные значения при его объявлении и метод вывода массива в матричном виде. Реализовать:
1. класс Matrix1, дружественный к классу Matrix, который будет осуществлять поиск максимального элемента каждой строки матрицы и сортировать строки матрицы в порядке убывания их максимальных элементов.
2. Функцию, дружественную к классу Matrix для сложения двух матриц.
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.09.2010, 21:56     Дружественные классы
Посмотрите здесь:

C++ Классы.Дружественные функции
C++ Дружественные функции и классы
Дружественные классы C++
Дружественные классы. C++
C++ Дружественные классы
Дружественные классы эллипс и круг C++
Дружественные функции и классы C++
Дружественные перегрузки операторов и дружественные классы C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Crudelis
Шаровик затейник
 Аватар для Crudelis
668 / 410 / 13
Регистрация: 06.05.2010
Сообщений: 1,109
28.09.2010, 01:17     Дружественные классы #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
//Создайте класс Matrix для хранения матрицы целого типа. Создать конструктор, который позволяет объекту этого класса
//принимать начальные значения при его объявлении и метод вывода массива в матричном виде. Реализовать: 
//1. класс Matrix1, дружественный к классу Matrix, который будет осуществлять поиск максимального элемента каждой
//строки матрицы и сортировать строки матрицы в порядке убывания их максимальных элементов. 
//2. Функцию, дружественную к классу Matrix для сложения двух матриц.
#include<iostream>
#include<time.h>
using namespace std;
class Matrix1;
class Matrix{
public:
    int **matr;
    int n,m;
    Matrix(int n, int m);
    ~Matrix();
    void Showm();
    friend void MatrPlus(Matrix&ob1,Matrix&ob2);
};
Matrix::Matrix(int n, int m){
        this->n=n;
        this->m=m;
        matr=new int*[n];
        for(int i=0;i<n;i++)
            matr[i]=new int[m];
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++)
                matr[i][j]=rand()%20;
        }
}
Matrix::~Matrix(){
    for(int i=0;i<n;i++)
        delete []matr[i];
    delete []matr;
}
void Matrix::Showm(){
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++)
                cout<<matr[i][j]<<"\t";
            cout<<endl;
        }
}
class Matrix1:public Matrix{
public:
    Matrix1(int n,int m):Matrix(n,m){cout<<"\n";};
    void SearchMax();
};
void Matrix1::SearchMax(){
    for(int k=0;k<n*m;k++){
    for(int i=0;i<n;i++){
        for(int j=0;j<m-1;j++){
            if(matr[i][j]<matr[i][j+1])
            {
                int temp;
                temp=matr[i][j];
                matr[i][j]=matr[i][j+1];
                matr[i][j+1]=temp;
            }
        }
    }
    }
}
void MatrPlus(Matrix&ob1,Matrix&ob2){
    for(int i=0;i<ob1.n;i++){
        for(int j=0;j<ob1.m;j++){
            ob1.matr[i][j]+=ob2.matr[i][j];
            cout<<ob1.matr[i][j]<<"\t";
        }
        cout<<endl;
    }
}
void main()
{
    Matrix1 ob(5,5),ob2(5,5);
    cout<<"Pervaya matrica:\n";
    ob.Showm();
    cout<<endl;
    cout<<"Otsortirovanaya matrica:\n";
    ob.SearchMax();
    ob.Showm();
    cout<<endl;
    cout<<"Vtoraya matrica:\n";
    ob2.Showm();
    cout<<endl;
    cout<<"Summa dvuh matric:\n";
    MatrPlus(ob,ob2);
}
Yandex
Объявления
28.09.2010, 01:17     Дружественные классы
Ответ Создать тему
Опции темы

Текущее время: 18:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru