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

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

Восстановить пароль Регистрация
 
metaluga145
243 / 244 / 20
Регистрация: 08.04.2013
Сообщений: 927
12.03.2014, 08:28     Move семантика (класс полиномов) #1
Доброго времени суток. Пишу простенький класс полиномов, в котором есть единственное приватное поле - это 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 семантика (класс полиномов)
Посмотрите здесь:

Деление многочленов(полиномов). доделать класс C++
C++ Семантика массивов char.
Синтаксис и семантика С++ , перечень. C++
move семантика C++
C++ Переумножение полиномов, где полином оформлен в класс
C++ Семантика перемещения - разобрать код
Что такое move семантика? C++
C++ Семантика перемещения rvalue\lvalue ссылок
C++ Класс полиномов
класс полиномов как переделать в динамический C++
Простой класс полиномов C++
Синтаксис и семантика блоков try… catch… C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
saden
 Аватар для saden
183 / 167 / 41
Регистрация: 27.01.2013
Сообщений: 788
12.03.2014, 09:00     Move семантика (класс полиномов) #2
polynomial(const polynomial &); - это и так конструктор копирования. Обычно именно он работает при присваивании.
gromo
 Аватар для gromo
367 / 266 / 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
640 / 561 / 89
Регистрация: 13.12.2012
Сообщений: 2,109
12.03.2014, 09:51     Move семантика (класс полиномов) #4
metaluga145, вряд ли, у Вас элементами мапы являются инты, там перемещай/копируй, одно и тоже будет
Yandex
Объявления
12.03.2014, 09:51     Move семантика (класс полиномов)
Ответ Создать тему
Опции темы

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