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

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

Восстановить пароль Регистрация
 
Ded_Vasilij
 Аватар для Ded_Vasilij
229 / 211 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
02.05.2013, 09:40     Перегруженный оператор вывода #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");
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.05.2013, 09:40     Перегруженный оператор вывода
Посмотрите здесь:

C++ Не вызывается перегруженный оператор
Перегруженный оператор ввода C++
Перегруженный оператор присваивания C++
Функтор и перегруженный оператор C++
C++ Перегруженный оператор вывода
Перегруженный постфиксный оператор ++ C++
Перегруженный оператор присваивания C++
Глобальный перегруженный оператор C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
DU
1477 / 1053 / 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");
}
Yandex
Объявления
02.05.2013, 10:47     Перегруженный оператор вывода
Ответ Создать тему
Опции темы

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