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

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

Войти
Регистрация
Восстановить пароль
 
metaluga145
243 / 244 / 20
Регистрация: 08.04.2013
Сообщений: 927
#1

Move семантика (класс полиномов) - C++

12.03.2014, 08:28. Просмотров 530. Ответов 3
Метки нет (Все метки)

Доброго времени суток. Пишу простенький класс полиномов, в котором есть единственное приватное поле - это map. Вот думаю надо ли писать move конструктор и оператор присвоения или нет. А если надо, то как. Кто разобрался уже, подскажите. Заодно, если увидите еще какие-то ошибки в коде, то замечания тоже приветствуются.
Зарание спасибо.
Кликните здесь для просмотра всего текста
polynomial.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
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
#pragma once
#include <map>
#include <iostream>
#include <iterator>
 
class polynomial
{
public:
    polynomial(void);
    polynomial(const polynomial &);
    //polynomial(polynomial &&);
    ~polynomial(void);
    void set(int, int);
    polynomial operator+ (const polynomial &) const;
    polynomial operator* (const polynomial &) const;
    polynomial& operator-- (int);
    polynomial& operator= (const polynomial &);
    //polynomial& operator= (const polynomial &&);
    bool operator== (const polynomial &);
    friend std::ostream & operator<<(std::ostream &os, const polynomial & right)
    {
        if (right.arr.begin() == right.arr.end())
            {
                os << 0;
                return os;
            }
 
        std::map<int, int>::const_reverse_iterator ritr = right.arr.rbegin();
        while (ritr != (std::prev(right.arr.rend())))
        {
 
            if (ritr->first == 0)
                os << ritr->second;
            if (ritr->first == 1)
                os << ritr->second << "x";
            if (ritr->first > 1)
                os << ritr->second << "x^" << ritr->first;
            ++ritr;
            if (ritr->second > 0) os << "+";
        }
        if (ritr->first == 0)
            os << ritr->second;
        if (ritr->first == 1)
            os << ritr->second << "x";
        if (ritr->first > 1)
            os << ritr->second << "x^" << ritr->first;
        return os;
    }
private:
    std::map<int, int> arr;
};

Кликните здесь для просмотра всего текста
polynomial.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
#include "StdAfx.h"
#include "polynomial.h"
#include <utility>
#include <iterator>
#include <algorithm>
 
polynomial::polynomial(void)
{
}
 
 
polynomial::polynomial(const polynomial & to_copy)
{
    this->arr = to_copy.arr;
}
 
 
polynomial::~polynomial(void)
{
}
 
 
void polynomial::set(int coeff, int power)
{
    this->arr[power] = coeff;
}
 
 
polynomial polynomial::operator+ (const polynomial & right) const
{
    polynomial temp;
    temp = *this;
    for(std::map<int, int>::const_iterator itr = right.arr.begin(); itr != right.arr.end(); ++itr)
        temp.arr[itr->first] += itr->second;
    return temp;
}
 
 
polynomial polynomial::operator* (const polynomial & right) const
{
    polynomial temp;
    for(std::map<int, int>::const_iterator itr1 = this->arr.begin(); itr1 != this->arr.end(); ++itr1)
        for(std::map<int, int>::const_iterator itr2 = right.arr.begin(); itr2 != right.arr.end(); ++itr2)
            temp.arr[itr1->first + itr2->first] += itr1->second*itr2->second;
    return temp;
}
 
 
polynomial& polynomial::operator-- (int)
{
    this->arr[0] = 0;
    std::map<int, int>::iterator itr;
    for(itr = std::next((this->arr.begin())); itr != this->arr.end(); ++itr)
    {
        this->arr[itr->first - 1] = (itr->first) * (itr->second);
        itr->second = 0;
    }
    itr = this->arr.begin();
    while (itr != this->arr.end())
        if (itr->second == 0)
            this->arr.erase(itr++);
        else ++itr;
    return *this;
}
 
 
polynomial& polynomial::operator= (const polynomial & right)
{
    this->arr = right.arr;
    return *this;
}
 
 
bool polynomial::operator== (const polynomial & right)
{
    return (this->arr.size() == right.arr.size()) && 
        std::equal(this->arr.begin(), this->arr.end(), right.arr.begin());
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.03.2014, 08:28     Move семантика (класс полиномов)
Посмотрите здесь:

move семантика - C++
Сейчас стало появляться нечто вроде такого: class X { public: X (const X&amp; lvalue); // copy constructor X (X&amp;&amp; rvalue);...

Что такое move семантика? - C++
Что такое move семантика? Добавлено через 6 минут Я правильно понимаю, что mov присваивание перемещает правый операнд на место...

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

Простой класс полиномов - C++
Есть методы для умножения, сложения и производной #include &lt;iostream&gt; #include &lt;cstdlib&gt; using namespace std; ...

класс полиномов как переделать в динамический - C++
Подскажите как из этого класса полиномов сделать динамический класс? //класс Polynom class Polynom{ private: unsigned int deg;...

Деление многочленов(полиномов). доделать класс - C++
Суть задания - сделать класс-полином со основными арифметическими операциями между многочленами. Сложение, вычитание и умножение я сделал,...

Переумножение полиномов, где полином оформлен в класс - C++
Проблема решения задачи состоит в том, что когда я все сделала функциями, все работало, но потребовали переопределение операторов, и тут...

Синтаксис и семантика С++ , перечень. - C++
Доброго времени суток всем. Не могли бы вы, посоветовать статьи, самоучители, сайты в которых бы информация излагалась бы следующим...

Семантика массивов char. - C++
Добрый день. Мы все знаем, что в C и С++ создав два массива подрят.. запросив элемент привышающий размерность первого мы зайдем во второй....

Синтаксис и семантика блоков try… catch… - C++
Не могу понять что нужно написать

Семантика перемещения и perfect forwarding - C++
Спасибо автору статьи http://www.cyberforum.ru/blogs/174410/blog826.html Но не понял кое что. А именно этот кусок. Прошу объяснить тех...

Семантика перемещения - разобрать код - C++
Допустим, есть такой код: vector&lt;T&gt; f() { vector&lt;T&gt; v(100000); return v; } ... vector&lt;T&gt; t =...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
saden
183 / 167 / 41
Регистрация: 27.01.2013
Сообщений: 788
12.03.2014, 09:00     Move семантика (класс полиномов) #2
polynomial(const polynomial &); - это и так конструктор копирования. Обычно именно он работает при присваивании.
gromo
370 / 269 / 24
Регистрация: 04.09.2009
Сообщений: 1,214
12.03.2014, 09:10     Move семантика (класс полиномов) #3
saden,
Цитата Сообщение от metaluga145 Посмотреть сообщение
Кто разобрался уже, подскажите
http://www.cprogramming.com/c++11/rv...-in-c++11.html
aLarman
641 / 562 / 89
Регистрация: 13.12.2012
Сообщений: 2,109
12.03.2014, 09:51     Move семантика (класс полиномов) #4
metaluga145, вряд ли, у Вас элементами мапы являются инты, там перемещай/копируй, одно и тоже будет
Yandex
Объявления
12.03.2014, 09:51     Move семантика (класс полиномов)
Ответ Создать тему
Опции темы

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