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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Изменить заданный числовой массив так, чтобы элементы были расположены в нем в обратном порядке http://www.cyberforum.ru/cpp-beginners/thread1116979.html
Доброго времени суток. Изменить заданный числовой массив так, чтобы элементы были расположены в нем в обратном порядке. Задача вроде бы элементарная, но че то никак не могу понять почему цикл не изменяет порядок #include <iostream> #include <iomanip> using namespace std;
C++ Вывести на экран все слова, количество букв в которых превышает введенное число Необходимо вывести на экран все слова, количество букв в которых превышает число, заданное пользователем с клавиатуры. (с клавиатуры задается произвольный текст, содержащий не более 10 строк, в каждой строке не более 80 символов.) http://www.cyberforum.ru/cpp-beginners/thread1116975.html
Написать функцию, которая заполняет квадратную матрицу числами по указанному правилу C++
Напишите функцию, которая заполняет квадратную матрицу числами по следующему правилу: в заштрихованной части матрицы расположены 1, а в не заштрихованной – нули. Массив является параметром функции. Добавлено через 11 часов 57 минут ребятки, спасайте!!
C++ Найти все простые положительные делители данного натурального числа
Help!: Дано натуральное число N. Найти все его простые положительные делители. Ещё с решением пожалуйста (алгоритмы)
C++ Заменить цифру 5 на слово «пять» http://www.cyberforum.ru/cpp-beginners/thread1116947.html
Cтроки символов C клавиатуры задается произвольный текст, содержащий не более 5 строк, в каждой строке не более 80 символов. В данном тексте заменить цифру 5 на слово «пять» и вывести полученный текст на экран. Помогите пожалуйста :) Если можно с комментариями!)
C++ Ретранслировать нажатия клавиш в другие окна Привет.Как можно реализовать следующий функционал: Есть два окна, в которые нужно отправлять комбинации клавиш, для этого я так понимаю нужно создать третие окно которые будет отправлять эти комбинации на другие. Как можно подобно реализовать ? подробнее

Показать сообщение отдельно
metaluga145
243 / 244 / 20
Регистрация: 08.04.2013
Сообщений: 927
12.03.2014, 08:28     Move семантика (класс полиномов)
Доброго времени суток. Пишу простенький класс полиномов, в котором есть единственное приватное поле - это 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());
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:17. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru