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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 31, средняя оценка - 4.97
-Andriy-
0 / 0 / 0
Регистрация: 28.04.2010
Сообщений: 26
#1

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

27.09.2010, 21:56. Просмотров 3808. Ответов 1
Метки нет (Все метки)

Помогите !!! Завтра надо сдавать а я ету тему совсем непонимаю...

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

Дружественные перегрузки операторов и дружественные классы - C++
#include <iostream> using namespace std; class person; class book { public: book(){}; int get_inf(person &a); void...

Дружественные классы - C++
Всем привет! Нашел в интернете как подружить два класса, вышло Но в моёй ситуции нужно классы поменять местами, а из-за это ничего...

Дружественные классы. - C++
Есть ли смысл в коде: class A{ ... public: bool ff(); } class B{

Дружественные классы - C++
Доброго времени суток, Господа. Собственно, хотел бы услышать Вашего мнения по поводу использования дружественных классов. Сколько книг...

Дружественные классы - C++
Есть два класса. первый - основной, в нем все нужные поля. второй, в нем должен быть некий метот который должен использовать поле основного...

Дружественные классы - C++
- У меня имеется класс: struct ListNodeBase { // ......... private: ListNodeBase *prev_, *next_; // связи с соседями....

1
Crudelis
Шаровик затейник
674 / 416 / 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);
}
3
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.09.2010, 01:17
Привет! Вот еще темы с ответами:

Шаблонные дружественные классы - C++
Походу с шаблоном разбираюсь, Node* стала приватным в моем классе-итераторе. #include &lt;iostream&gt; template&lt;class T&gt; class iterator; ...

Дружественные функции и классы - C++
Доброго времени суток ! Может у кого - нибудь есть похожие исходники или мысли по поводу данного задания ?! Помогите пожалуйста ! ...

Классы.Дружественные функции - C++
Пример с книги &quot;Visual CPP 6 - Руководство Разработчика&quot;. Тема: &quot;Классы.Дружественные ф-ции&quot;. Исправте ошибки и рассказыте более подробнее...

Дружественные функции и классы - C++
Добрый вечер, я готовлюсь к госам и там есть такая штука как Дружеские функции и классы, и вот хотел спросить зачем ваше нужны дружеские...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru