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

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

Войти
Регистрация
Восстановить пароль
 
Ded_Vasilij
231 / 213 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
#1

Перегруженный оператор вывода - C++

02.05.2013, 09:40. Просмотров 688. Ответов 1
Метки нет (Все метки)

Пытаюсь написать шаблон для работы с бинарными деревьями поиска.
Возникла проблема - с ходу не соображу что к чему. при попытке распечатать дерево выдает ошибку
" error LNK2019: ссылка на неразрешенный внешний символ "class std::basic_ostream<char,struct std::char_traits<char> > & __cdecl operator<<(class std::basic_ostream<char,struct std::char_traits<char> > &,class Tree<double>)" (??6@YAAAV?$basic_ostream@DU?$char_traits@D@std@@@std@@AAV01@V?$Tree@N@@@Z) в функции _main"
Я понимаю, что ошибка мелочная, но тем не менее...
вот код:
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
#pragma once
template <class T>
class Tree
{
    struct TrElem
    {
        TrElem* Left;
        TrElem* Right;
        T Key;
        TrElem(TrElem* R,TrElem* L, T val);
    };
    TrElem* root;
    void Print(TrElem* El);
public:
    
    Tree();
    virtual ~Tree();
    void Destroy();
    void Add(T val);
    
    friend std::ostream& operator<<(std::ostream& o, const Tree Tr);    
};
template <class T>
Tree<T>::TrElem::TrElem(TrElem*R,TrElem*L, T val)
{
    Right = R;
    Left = L;
    Key = val;
}
 
template <class T>
Tree<T>::Tree():root(0)
{
 
}
template <class T>
void Tree<T>::Destroy()
{
    if(!root)
    {
        return;
    }
    Destroy(root->Right);
    Destroy(root->Left);
    delete root;
}
 
template <class T>
Tree<T>::~Tree()
{
    //Destroy();
}
 
template <class T>
void Tree<T>::Add(T val)
{
    if(!root)
    {
        root = new TrElem(0,0,val);
        return;
    }
    TrElem*& temp = root; 
    while (temp != 0)
    {
        if(val == temp->Key)
        {
            return;
        }
        if(val > temp->Key)
        {
            temp = temp->Right;
        }
        else
        if (val < temp-> Key)
        {
            temp=temp->Left;
        }
    }
    temp = new TrElem(0,0,val);
}
template <class T>
void Tree<T>::Print(TrElem* El)
{
 
    if(!El)
    {
        return;
    }
    Print(El->Right);
    cout << El->Key;
    Print(El->Left);
    
}
template <class T>
std::ostream& operator<<(std::ostream& o, const Tree<T> &Tr)
{
    
    Tr.Print(o);
    return o;
}
#include<iostream>
#include "tree.h"
using namespace std;
void main()
{
    Tree<double> Tr;
    Tr.Add(1);
    Tr.Add(2);
    Tr.Add(-5);
    cout << Tr;
    //Tr.Destroy();
    system("pause");
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.05.2013, 09:40
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Перегруженный оператор вывода (C++):

Перегруженный оператор вывода - C++
Есть базовый класс Точка и его наследник Круг. Как в Круге использовать operator&lt;&lt; для Точки? Надо вывести координаты центра круга ...

перегруженный оператор << - C++
подскажите как перегрузить оператор &lt;&lt; для класса как описать само перегружение friend ostream&amp; operator &lt;&lt; (ostream &amp;c, const...

Перегруженный оператор - C++
MathClass = Harry; Раньше я думал, что перегрузка - это предоставление оператору функций, которых, он изначально не имел. Что...

Глобальный перегруженный оператор - C++
Как организовать работу глобального перегруженного оператора &quot;-&quot;, который должен сравнивать 5 массивов(экземпляры класса). Помогите,...

Функции и перегруженный оператор - C++
Помогите реализовать на С++: 1.Определить пользовательский тип данных fraction (дробь), представляющий собой структуру из 2х полей:...

Не вызывается перегруженный оператор - C++
#include&lt;iostream&gt; using namespace std; struct dates { int num; int count; dates *back; dates *forward; }; class...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
DU
1483 / 1059 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
02.05.2013, 10:47 #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
#include <iostream>
using namespace std;
 
template <class T>
class Tree
{
    struct TrElem
    {
        TrElem* Left;
        TrElem* Right;
        T Key;
        TrElem(TrElem* R,TrElem* L, T val);
    };
    TrElem* root;
    void Print(TrElem* El) const;
public:
    
    Tree();
    virtual ~Tree();
    void Destroy();
    void Add(T val);
    
    template <typename U>
    friend std::ostream& operator<<(std::ostream& o, const Tree<U>& Tr);
};
 
template <class T>
Tree<T>::TrElem::TrElem(TrElem*R,TrElem*L, T val)
{
    Right = R;
    Left = L;
    Key = val;
}
 
template <class T>
Tree<T>::Tree():root(0)
{
 
}
template <class T>
void Tree<T>::Destroy()
{
    if(!root)
    {
        return;
    }
    Destroy(root->Right);
    Destroy(root->Left);
    delete root;
}
 
template <class T>
Tree<T>::~Tree()
{
    //Destroy();
}
 
template <class T>
void Tree<T>::Add(T val)
{
    if(!root)
    {
        root = new TrElem(0,0,val);
        return;
    }
    TrElem*& temp = root; 
    while (temp != 0)
    {
        if(val == temp->Key)
        {
            return;
        }
        if(val > temp->Key)
        {
            temp = temp->Right;
        }
        else
        if (val < temp-> Key)
        {
            temp=temp->Left;
        }
    }
    temp = new TrElem(0,0,val);
}
template <class T>
void Tree<T>::Print(TrElem* El) const
{
 
    if(!El)
    {
        return;
    }
    Print(El->Right);
    cout << El->Key;
    Print(El->Left);
    
}
 
template <class T>
std::ostream& operator<<(std::ostream& o, const Tree<T>& Tr)
{
    
    //Tr.Print(o); ????
    return o;
}
 
 
void main()
{
    Tree<double> Tr;
    Tr.Add(1);
    Tr.Add(2);
    Tr.Add(-5);
    cout << Tr;
    //Tr.Destroy();
    system("pause");
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.05.2013, 10:47
Привет! Вот еще темы с ответами:

Не работает перегруженный оператор - C++
Привет, у меня есть класс такой: class Sterling { private: long pounds = 0; int shillings = 0; int pennys = 0; public:...

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

Перегруженный оператор ввода - C++
Всем привет, как правильно создать перегруженный оператор ввода для инициализации данных об обьекте к примеру class Planet{ ...

Функтор и перегруженный оператор - C++
захотел понять многопоточность в новом стадарте с++11 - смотрю http://sergeyteplyakov.blogspot.ru/2012/05/c-11-faq.html#std-threads - вижу...


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

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

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