Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
Другие темы раздела
C++ Как верно узнать размер указателя ? СBaseTest* pTest = { new СBaseTest, new СOther }; Нужно узнать размер pTest https://www.cyberforum.ru/ cpp-beginners/ thread1210182.html C++ Преобразовать массив так чтобы все ненулевые элементы предшествовали нулевым
Задан массив целых чисел, среди которых есть 0. Преобразовать массив так чтобы все ненулевые элементы предшествовали нулевым
C++ Создайте функцию нахождения количества элементов одномерного массива, по модулю превосходящего введенное https://www.cyberforum.ru/ cpp-beginners/ thread1210177.html
Помогите пожалуйста!!! Создайте функцию нахождения количества элементов одномерного массив, по модулю превосходящего введенное с клавиатуры значение k. Примените функцию к целочисленным массивам A(N), B(M), где N и M - заданы.
C++ Как правильно освободить память https://www.cyberforum.ru/ cpp-beginners/ thread1210175.html
Написал вот такой костыль: wchar_t* getDate() { time_t seconds = time(NULL); tm timeinfo = *(localtime(&seconds)); return _wasctime(&timeinfo); }; Теперь его использую в main:
C++ Проверка корректности введенного города игра "Города"
Здравствуйте, пишу программку "Города", т.е. пользователь называет какой-нибудь город, допустим, "Омск". Компьютер считывает последнюю букву и на нее осуществляет поиск города в векторе (города туда записываются из файла) и выдает этот город, предварительно записав его в "использованные". Все подфункции работают, единственная проблема с проверкой: следует проверить, ввел ли пользователь город на...
C++ Из данной задачи составить параллельную программу вычисления произведения элементов вектора https://www.cyberforum.ru/ cpp-beginners/ thread1210159.html
Помогите, пожалуйста, из данной задачи составить параллельную программу вычисления произведения элементов вектора, используя функцию широковещательной рассылки #include "mpi.h" #include <time.h> #include <stdio.h> #include <stdlib.h> int main (int argc, char *argv)
C++ Решето Эратосфена с графикой Нужно сделать решето эратосфена, с введением чисел от 2 до N, и чтобы выводил все числа и вычеркивал, не знаю как это реализовать, знания языка на уровне структурного, нужно сделать примерно как на картинке, кодю в VisualStudio, ну и не очень знаком вообще с реализацией графики, помогите https://www.cyberforum.ru/ cpp-beginners/ thread1210138.html Передвинуть элементы в массиве указателей на объекты fstream C++
Здравствуйте. Есть прога в которой одновременно надо обрабатывать до 10 файлов. Для этого создан массив указателей на fstream. Проблема такая: при закрытии, например 4-го файла, надо в массиве указателей на файлы сдвинуть элементы к началу массива, начиная с 4 позиции. То есть: fstream fList; //массив указателей на файлы ........................... for (int i = 4; i < 10; i++) ...
C++ Размерность массива без ее ввода с клавиатуры https://www.cyberforum.ru/ cpp-beginners/ thread1210103.html
В условии сказано:" Из файла (имя файла вводится с клавиатуры) считывается массив целых чисел. Размер массива заранее неизвестен...". дальше массив нужно обработать. Как сделать так, чтоб размер массива не вводить с клавиатуры, а он определялся сам после считывания из файла?
C++ Начинающий, посоветуйте, с чего начать? https://www.cyberforum.ru/ cpp-beginners/ thread1210099.html
Здравствуйте, давно хотел заняться программированием, и сейчас, со всей серьезностью решил изучать. Помогите решить непростой для меня вопрос. C чего начать?, какую литературу и какой язык программирования. Облазил много форумов и на каждом, советуют разное, по этому не могу определиться что из предложенного нужно всерьез начать изучать. Очень надеюсь на вашу помощь.
Какую сортировку массива применить, чтобы посчитать количество перестановок двух соседних элементов? C++
Всем привет. Я раньше создавал подобную тему, но решил создать новую. Вопрос следующий. Скажите, каким видом сортировки массива можно воспользоваться, чтобы посчитать количество перестановок двух соседних элементов? Дело в том, что сортировка пузырьком - медленный способ. А в сортировке слиянием, как мне сказали, подсчитать количество перестановок проблематично. Заранее спасибо. Добавлено...
C++ Найти сумму ряда https://www.cyberforum.ru/ cpp-beginners/ thread1210081.html
Здравствуйте уважаемые форумчане! Нуждаюсь в помощи. Имеется ряд http://firepic.org/images/2014-06/16/4mby1f0q9sec.png Необходимо найти его сумму. Visual C++, консольное приложение. Желательно с комментариями, чтобы разобраться :) Заранее огромное спасибо за помощь!
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179
0

С2248 и Френдфункция? - C++ - Ответ 6328687

17.06.2014, 10:06. Показов 1111. Ответов 5
Метки (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день, казалось бы вчера допилил лабу(не без помощи форумчан,за которую признателен) , но возникла проблема.
В проге есть два класса, вектор и матрица. Матрица - массив векторов. Собственно, требуется реализовать оператор <<, для Вектора его реализовать у меня получилось.

Для матрицы его выразил корректно(как мне кажется), но программа не получает доступа к приватным элементам n и vlength.Честно говоря, вообще не понимаю почему. Так все действия делаются. пробовал писать обычной функцией вывод - работает. Спасите-помогите.


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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
// Oop3.cpp : Defines the entry point for the console application.
#include "stdafx.h"
#include <iostream>
using namespace std;
#include <iostream>
#include <fstream>
#pragma warning(disable : 4996)
 
 
template<typename X> class vectr{
public:
    vectr(){ data_ = NULL; } // дефолтный конструктор для возможности создания массива
    vectr(int vlength2)  { vlength = vlength2; data_ = new X[vlength]; }
 
    void vfill()
    {
        for (int i = 0; i < vlength; i++)
            cin >> data_[i];
    }
 
    X& operator[](int i);
    vectr<X> operator+(vectr &t);
    vectr<X> operator=(vectr &t);
    template<typename X>
    friend ostream& operator<<(ostream& as, vectr<X>& u);
private: X* data_;
         int vlength;
};
 
template<typename X>
X& vectr<X>::operator[](int i)
{
    return data_[i];
}
 
template<typename X>
vectr<X> vectr<X>::operator+(vectr &t)
{
    vectr<X> temp(vlength);
    for (int i = 0; i < vlength; i++)
        temp.data_[i] = data_[i] + t.data_[i];
    return temp;
}
 
template<typename X>
vectr<X> vectr<X>::operator=(vectr &t)
{
    if (this != &t)
    {
        vlength = t.vlength;
        data_ = new X[vlength];
 
        for (int i = 0; i < vlength; i++)
            data_[i] = t.data_[i];
    }
    return *this;
}
 
 
template<typename X>
ostream& operator<<(ostream& as, vectr<X>& u)
{
    for (int i = 0; i < u.vlength; i++){
        as << u.data_[i];
    }
    cout << endl;
    return as;
}
template<class T>
class matrix
{
    private:
 int n, vlength;
    T *b;
public:
    matrix() { b = NULL; };
    matrix(int n2, int vlength2)
    {
        n = n2;  vlength = vlength2;
        b = new T[n];
        for (int i = 0; i < n; ++i)
            b[i] = T(vlength);
    }
 
    void entervalue()
    {
        T v2(vlength);
        for (int j = 0; j < n; j++)
        {
            cout << "enter vector" << endl;
            v2.vfill();
            b[j] = v2;
        }
        v2 = b[0];
        cout << endl;
        for (int i = 0; i < n; i++)
        cout << b[i];
    }
 
    matrix operator+(matrix &t);
    matrix operator=(matrix &t);
    vectr<int>& operator[](int i);
    template<class T>
    friend ostream& operator<<(ostream& as,matrix& u);
    /*void show()
    {
        cout << endl;
        for (int i = 0; i < n; i++)
            cout<< b[i];
    } */
};
 
 
template<class T>
matrix<T> matrix<T>::operator=(matrix<T> &t)
{
    if (this != &t){
        n = t.n;
        for (int i = 0; i < n; i++)
            b[i] = t.b[i];
    }
    return *this;
}
template<class T>
matrix<T> matrix<T>::operator+(matrix &t)
{
    matrix<T> temp(n,vlength);
    for (int i = 0; i < n; i++)
        temp.b[i] = b[i] + t.b[i];
    return temp;
}
template<class T>
vectr<int>& matrix<T>::operator[](int i)
{
    return b[i];
}
 
// написать френдфункцию, которая это делает за место оператора.
template<class T>
ostream& operator<<(ostream& as,matrix<T>& u)
{
    cout << endl;
    for (int i = 0; i < u.n; i++)
        as << u.b[i];
    return as;
} 
int _tmain(int argc, _TCHAR* argv[])
{
    int n;
    int vlength; 
    cout << "enter number of vectors" << endl;
    cin >> n;
    cout << "enter length of vector" << endl;
    cin >> vlength;
    /* cout << "testing vectr class" << endl;
    vectr<int> v2(vlength);
    v2.vfill();
    cout << v2;
    vectr<int> v(vlength);
    v.vfill();
    v = v + v2;
    cout << v; */
 
 
    //сделаем матрицу векторов.
    matrix<vectr<int>> Mt(n, vlength);
    Mt.entervalue();
    cout << "testing << operator for matrix class";
    cout << Mt;
    //Mt.show();
    //cout << "testing = operator for matrix class";
    matrix<vectr<int>> testm(n, vlength);
    cout << "enter second matrix"<<endl;
    //testm.entervalue();
    //Mt = testm;
    //cout << Mt;
    //cout << "now testing + operator" << endl;
    //testm = Mt + testm;
//  cout << testm;
    
    return 0; 
}


Вернуться к обсуждению:
С2248 и Френдфункция? C++
0
Лучшие ответы (1)
Заказать работу у эксперта
17.06.2014, 10:06
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru