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

перегрузка операций для однонаправленных списков - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с файлами. Обработка исключений http://www.cyberforum.ru/cpp-beginners/thread314684.html
Будьте добры, помогите с решением задач. Заранее благодарю откликнувшихся! :) 1. Создать класс для работы с файлами. В классе реализовать функцию поиска в исходном текстовом файле слова max длины. Найденное слово переписать в новый файл. 2. Реализовать шаблон класса Stack, реализующий стек. Для представления элемента стека использовать шаблон класса Node. Определить функции добавления,...
C++ Одномерные массивы. Объявить два динамических массива целых чисел.Написать функции для заполнения их случайными значениями и вывода результатов на экран.Первым на печать вывести массив, содержащий наибольшее значение(с помощью функций). Напечатать также это значение и его порядковый номер.Отсортировать по не возрастанию с помощью включения. Диапозон значений (-50:150). P.S. Прошу помогите как можно скорее.... http://www.cyberforum.ru/cpp-beginners/thread314681.html
C++ Вычислить с заданной точностью
http://i22.***********/big/2011/0607/95/02db2277e85b5a1d8e82919de7293995.jpg
Вычислить по формуле C++
http://i22.***********/big/2011/0607/27/df317010d86026ed4942a3503d6c6627.jpg
C++ Двойная буферизация, не перерисовывает http://www.cyberforum.ru/cpp-beginners/thread314660.html
создаю игру "змейка" использую двойнуюю буферизацию, окно перестало мигать, но оно не перерисовывает область окна после того как там было что-то нарисовано, вот код WM_PAINT , может я что-то не так сделал? заранее спасибо case WM_PAINT : GetClientRect(hWnd, &Rect); hDC = BeginPaint(hWnd, &PaintStruct); hCmpDC = CreateCompatibleDC(hDC); hBmp =...
C++ Сообщение об ошибке fatal error C1004: unexpected end-of-file found //Navy.h #pragma once #include "resource.h" #include "Ship.h" #define DECK 176 #define DAMAGE 'X' #define MISS '0' typedef unsigned char Field; подробнее

Показать сообщение отдельно
savzhik
2 / 2 / 0
Регистрация: 07.06.2011
Сообщений: 59

перегрузка операций для однонаправленных списков - C++

07.06.2011, 02:00. Просмотров 864. Ответов 0
Метки (Все метки)

Задача вот в чём: АТД - однонаправленный список в элементами char. Дополнительно перегрузить следущие операции: + объединить списки; -- удалить элемент из начала; ==проверка на равенство.
Проблема с перегрузкой операций. Ругается на часть кода где перегружается ==, если закоментить, то при выводе объединнёного списка и списка с удалённым элементом, выводит иероглифы.
Помогите кто может!
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
#include <iostream>
#include <cstring>
using namespace std;
 
struct Element
{
    char data;
    Element *next; 
};
 
class List
{
    Element *pHead;     
        Element *pPrev;     
public:
        List();
        ~List();
        void addToList(char data);
        void printList();
        void delAllList();
        friend List operator +(List&, List&);
        friend List operator --(List&);
        friend List operator ==(List&, List&);
};
List::List()
{
        pHead = NULL;
}
 
List::~List()
{
    delAllList();
}
void List::addToList(char data)
{
        Element *temp = new Element;
        if(pHead == NULL)
            pHead = temp;
        else
            pPrev->next = temp;
            temp->data = data;
            temp->next = NULL;
            pPrev = temp;
}
void List::printList()
{
        Element *pTemp = pHead;
        while(pTemp != NULL)
        {
            cout << pTemp->data << " ";
            pTemp = pTemp->next;
        }
        cout << endl;
}
void List::delAllList()
{
    while(pHead != NULL)
        {
            Element *pTemp = pHead;
            pHead = pHead->next;
            delete pTemp;
        }
}
List operator +(List& l1, List& l2)
{   
    List l3;
    l3.pHead=l1.pHead;
    l1.pPrev->next=l2.pHead;
    return l3;
}
List operator --(List& l4)          
{   
    List l5; 
    Element *pTemp = l4.pHead;
        l5.pHead = l4.pHead->next;
        delete pTemp;   
    return l5;
}
List operator ==(List& l6, List& l7)
{   
    Element *p1Temp = l6.pHead;
    Element *p2Temp = l7.pHead;
    while(p1Temp != NULL)
    {
        if(p1Temp==p2Temp)
        {
            p1Temp=p1Temp->next;
            p2Temp=p2Temp->next;
        }
        else
        {
            cout << "Списки не одинаковы";
            return 0;
        }
    }
    cout << "Списки одинаковы";
    return 1;               
}
int main(void)
{
    char x;
    List a,b,c;
    cout << "Введите элементы 1-го списка:" << endl;    
    for(int i = 0; i < 3; i++)
    {
        cout << "Введите элемент " << i+1 << ' ';
        cin >> x;   
        a.addToList(x);
    }
    cout << "Введите элементы 2-го списка:" << endl;    
    for(int i = 0; i < 3; i++)
    {
        cout << "Введите элемент " << i+1 << ' ';
        cin >> x;   
        b.addToList(x);
    }
    cout << "1-й список:" << endl;  
    a.printList();
    cout << "2-й список:" << endl;
    b.printList();
    --a;
    cout << "1-й список без последнего элемента: " << endl;     
    a.printList();
    a==b;
    c=a+b;
    cout << "2 списка объединены в один:" << endl;  
    c.printList();
    return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru