С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
5 / 5 / 5
Регистрация: 16.12.2013
Сообщений: 463

Как в двусвязном списке сделать перегрузку оператора присваивание

07.05.2016, 17:10. Показов 2250. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Мне нужно перегрузить оператор =, так чтобы один объект класса "Двусвязный список" присваивался другом объекту.
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
  class MyList{  //Список MyList
        int x,count_;
        MyList *Head,*Tail,*Next,*Prev;
    public:
        MyList():Head(NULL),Tail(NULL),count_(0){}; //Инициализация с помощью конструктора по умолчанию
        void operator+(int);
        void Show();
        void operator-(int); //Функция принимает целочисленный параметр, обозначающий номер удаляемого элемента
         void operator+=(int);
          void operator=(MyList&);
        ~MyList();
    };
 *ДОБАВЛЕНИЕ ЭЛЕМЕНТА В СПИСОК*/
   void MyList::operator+(int x){
        MyList *temp=new MyList;
        temp->x=x;
        temp->Next=NULL;
        count_++;
        if (!Head){
            temp->Prev=NULL;
            Head=temp;
            Tail=Head;
        } else {
            temp->Prev=Tail; //Указываем, что предыдущим элементом списка относительно добавленного, будет последний элемент существующего списка
            Tail->Next=temp; //Следующий за последним существующим это непосредственно сейчас добавляемый элемент списка
            Tail=temp;       //После того как указали что есть настоящий и что предыдущий, объявляем, что последний существующий это только что добавленный элемент
        }
    }
 ...
 
void MyList::operator=(MyList &a)
 {
        MyList *t=Head;
        while (t)
        {
        //  t=a.t->x;
        //  a.t=a.t->Next;
           // cout<<t->x<<" ";
           
        }
        cout<<"\n\n";
    }
int main(){
 MyList List1[3];
List1[0]+10;
    List1[0]+20;
List1[1]=List1[0]; //перегрузка
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.05.2016, 17:10
Ответы с готовыми решениями:

Как сделать в данной программе перегрузку оператора?
Нужно сделать, чтобы в этой программе была перегрузка оператора (любого). #include &lt;vcl.h&gt; #include &lt;fstream.h&gt; ...

Как организовать поиск в двусвязном списке?
Есть класс двусвязный список где каждый элемент имеет большое количество полей (Имя, Фамилия, Отчество, номер телефона, дата рождения ) ,...

Как найти k-ый элемент в двусвязном списке?
Задание состоит в том, чтобы найти m-ый элемент в двусвязном списке и вывести его на экран.вот моя попытка void Spisok:: find() { ...

1
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
07.05.2016, 17:40
не придираясь для вашего кода можно сделать так
C++
1
2
3
4
5
6
7
8
9
10
void MyList::operator=(MyList &a)
 {
// удалить старый список как в деструкторе затем
        MyList *p = a.Head;
        while(p)
        {
            *this += p->x; // operator+=(int) как я понимаю добавляет элемент в список
            p = p->Next;
        }
}
Добавлено через 3 минуты
а вообще реализация плохая, свалено все в кучу и может запутать. посмотрите примеры в закрепленных темах по спискам и мой совет переписать
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.05.2016, 17:40
Помогаю со студенческими работами здесь

Как работает вставка в двусвязном списке?
Привет всем! я не понимаю как работает вставка в двусвязном списке, а точне не понимаю зачем писать нужно вот такую строку...

Поиск в двусвязном списке
#include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;cstring&gt; #include &lt;windows.h&gt; using namespace std; struct element{ ...

Поиск в двусвязном списке
Доброго времени суток. Помогите написать код, который ищет в двусвязном списке елемент по его значению. Тоесть идёт запрос в консоле...

Сортировка в двусвязном списке
Здравствуйте! Есть класс List, в него вложен класс Node, в Node в качестве данных используется класс Circle Задание: Написать для...

Ошибка в двусвязном списке
Задача - сделать очередь с приоритетным исключением на основе двухсвязного списка. Проблема в том, что элементы не всегда становяться по...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru