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

Перегрузка операций - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Строки http://www.cyberforum.ru/cpp-beginners/thread1061692.html
Доброго времени суток, уважаемые. Сколько не парюсь над куском кода, так и не пойму, почему я не могу применить string в этом случае? А может я просто делаю это не правильно? struct students { string surname; int year_birth; int year_acquisition; int phys, math, info;
C++ Построить матрицу расстояний между всеми точками. Найти равноудаленные точки, если такие есть, и напечатать их номера Всем привет. Помогите написать программу... На плоскости заданы n точек своими координатами. Построить матрицу расстояний между всеми точками. Найти равноудаленные точки, если такие есть, и напечатать их номера. Заранее спасибо!!! http://www.cyberforum.ru/cpp-beginners/thread1061690.html
C++ Разработать функцию поэлементного умножения массива на константу
Ребята, помогите написать программу на языке C++ ! Нужно разработать функцию поэлементного умножения массива на константу. Ну и результат вывести на экран, но это я и сам могу сделать :)
Работа с указателями C++
Дана динамическая целочисленная матрица. Построить динамический одномерный массив, каждый элемент которого равен сумме элементов одной строке исходной матрицы. Освободить память от матрицы, найти произведение элементов одномерного массива и записать его как динамическую переменную. Все исходные данные, результаты и соответствующие адреса распечатать. Из этого всего меня больше...
C++ Решение линейных сравнений по модулю a*x = b (mod m) http://www.cyberforum.ru/cpp-beginners/thread1061668.html
помогите для курсовой написать программу для решения линейных сравнений по модулю (a*x = b (mod m)) и систем таких сравнений. http://en.wikipedia.org/wiki/Simultaneous_congruence#System_of_linear_congruences с чего начать?
C++ Ошибка при компиляции OpenGl Игры Делаю игру по туториалу. Вот код игры: #include <glut.h> #include <stdlib.h> using namespace std; class snake{ public: подробнее

Показать сообщение отдельно
Lilitanna
0 / 0 / 0
Регистрация: 10.03.2013
Сообщений: 15
02.01.2014, 11:55     Перегрузка операций
Нужно выполнить две перегрузки:
1) удаление элемента если он пустой;
2) сравнение по названию(равные).

Подскажите как это реализовать. Читаю..вроде не сложно..но не пойму как правильно это сделать...


Unit2.h
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
#ifndef Unit2H
#define Unit2H
#include <system.hpp>
#include <StdCtrls.hpp>
 
typedef struct ListElem{
AnsiString data;
struct ListElem* next;
} *Furniture;
 
 
class SortedList
{
        private:
          Furniture top;
        public:
          SortedList();
          ~SortedList();
          void AddEl(AnsiString info);
          void DelEl();
          void PrintList(TMemo * mem);
          void PrintEl(TMemo * mem, size_t i, size_t j );
 
};
 
#endif
Unit2.cpp

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
#pragma hdrstop
 
#include "Unit2.h"
#include <cstring>
#include <iostream.h>
 
 
SortedList :: SortedList()
{
    top=NULL;
}
SortedList :: ~SortedList()
{
       Furniture tmp;
    for(tmp = top; tmp;  tmp = tmp->next )
    {
            delete tmp;
    }
}
 
 
void SortedList :: AddEl(AnsiString info)
{
    Furniture tmp, tmp2;
 
    for(tmp = top,tmp2=NULL; tmp; tmp2 = tmp, tmp = tmp->next )
    {
            if( strcmpi(tmp->data.c_str(),info.c_str())>=0 )
                    break;
    }
 
    tmp = new  ListElem;
    tmp->data = info;
 
    if(tmp2!=NULL)
    {
        tmp->next = tmp2->next;
        tmp2->next = tmp;
    }
    else
    {
        tmp->next = top;
        top = tmp;
    }
}
void SortedList :: PrintList(TMemo * mem )
{
    Furniture tmp;
    mem->Clear();
    for(tmp = top; tmp;  tmp = tmp->next)
    {
            mem->Lines->Add(tmp->data.c_str());
    }
}
 
 
void SortedList :: DelEl()
{
        Furniture tmp = NULL;
    if(top!= NULL)
            tmp = top->next;
        delete top;
        top = tmp;
}
 
 
void SortedList :: PrintEl(TMemo *mem,size_t i, size_t j )
{
    Furniture tmp = top;
    mem->Clear();
    j -= i;
    for(;i>0;--i)
            if(tmp)
                    tmp=tmp->next;
    for(; tmp && j>0 ; --j, tmp = tmp->next )
    {
            mem->Lines->Add(tmp->data.c_str());
    }
 
}
 
//-----------------------------------------------------------------
#pragma package(smart_init)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru