Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
awashwinter
0 / 0 / 2
Регистрация: 05.10.2015
Сообщений: 19
1

Создание класса-списка на основе кода со списком без класса

14.03.2016, 19:32. Просмотров 232. Ответов 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
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
#include <iostream>
#include <cstdlib>
using namespace std;
struct item
{
    int digit;
    struct item *next;
    struct item *prev;
}; 
using Item = item;
 
/* Структура, описывающая многоразрядное число */
struct mnumber
{
    Item *head;
    Item *tail;
    int n;
};
using MNumber = mnumber;
 
MNumber CreateMNumber(char *initStr);
void AddDigit(MNumber *number, int digit);
void PrintMNumber(MNumber number);
MNumber SumMNumber(MNumber n1, MNumber n2);
int main()
{
    char *num1 = new char[1000];
    char *num2 = new char[1000];
    cout << "Enter first string (numbers): ";
    cin >> num1;
    cout << "Enter second string (numbers): ";
    cin >> num2;
    MNumber a = CreateMNumber(num1);
    MNumber b = CreateMNumber(num2);
    MNumber c = SumMNumber(a, b);
    PrintMNumber(a);
    PrintMNumber(b);
    cout<<"\nSumm\t";
    PrintMNumber(c);
    getchar();
    delete[] num1;
    delete[] num2;
    system("pause");
    return 0;
}
 
/* Создает многоразрядное число из цифр строки */
MNumber CreateMNumber(char initStr[])
{
    MNumber number = { NULL, NULL, 0 };
    int n;
    for (n = strlen(initStr) - 1; n >= 0; n--)
    {
        AddDigit(&number, initStr[n] - '0');
    }
 
    return number;
}
 
/* Добавляет цифру в многоразрядное число */
void AddDigit(MNumber *number, int digit)
{
    Item *p = (Item *)malloc(sizeof(Item));//Функция malloc выделяет блок памяти, размером sizemem байт, и возвращает указатель на начало блока.
                                           //Содержание выделенного блока памяти не инициализируется, оно остается с неопределенными значениями.
    p->digit = digit;
    p->next = p->prev = NULL;
 
    if (number->head == NULL)
    {
        number->head = number->tail = p;
    }
 
    else
    {
        number->tail->next = p;
        p->prev = number->tail;
        number->tail = p;
    }
    number->n++;
}
 
/* Возвращает сумму двух многоразрядных чисел */
MNumber SumMNumber(MNumber n1, MNumber n2)
{
    MNumber sum = CreateMNumber("");
    Item *p1 = n1.head, *p2 = n2.head;
    int digit, pos = 0, s1, s2;
 
    while (p1 || p2)
    {
        if (p1)
        {
            s1 = p1->digit;
            p1 = p1->next;
        }
 
        else s1 = 0;
 
        if (p2)
        {
            s2 = p2->digit;
            p2 = p2->next;
        }
 
        else s2 = 0;
 
        digit = (s1 + s2 + pos) % 10;
        pos = (s1 + s2 + pos) / 10;
        AddDigit(&sum, digit);
    }
 
    if (pos) AddDigit(&sum, pos);
 
    return sum;
}
void PrintMNumber(MNumber number)
{
    Item *p = number.tail, *temp = number.tail;
 
    cout<<"\nNumber: ";
 
    while (p)
    {
        if ((temp->digit == 0) && (p->prev != NULL))
        {
            temp = temp->prev;
            p = p->prev;
        }
        else
        {
            cout<< p->digit;
            p = p->prev;
        }
    }
 
    free(p);
}
Заранее спасибо.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.03.2016, 19:32
Ответы с готовыми решениями:

Как построить экземпляр дочернего класса на основе готового экземпляра базового класса?
Если уже есть готовый объект базового класса. Могу я построить экземпляр...

Создание списка, хранящего объекты класса
Помогите, пожалуйста, придумать реализацию связного списка, который хранил бы в...

Вызвать конструктор производного класса без конструктора базового класса
Здравствуйте! У меня есть базовый класс треугольник и производный класс...

Создать экземпляр класса без явного указания членов класса
Если у меня есть два конструктора, один из которых по умолчанию, а второй...

Вызов метода класса без создания экземпляра класса.
В общем мне для функционирования одной программы нужно постоянно вызывать метод...

1
awashwinter
0 / 0 / 2
Регистрация: 05.10.2015
Сообщений: 19
16.03.2016, 18:17  [ТС] 2
В общем помощи не дождался, сделал сам. Пользуйтесь, кому надо. Если найдете ошибки, прошу написать о них.
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
#include <iostream>
#include <cstdlib>
using namespace std;
struct item
{
    int digit;
    item *next;
    item *prev;
    item *head;
    item *tail;
    int n;
};
class List
{
public:
    item *head;
    item *tail;
    List(){ head = NULL; }//constructor
    ~List();//destructor
    item CreateMNumber(char *initStr);
    void AddDigit(item*number, int digit);
    void PrintMNumber(item number);
    item SumMNumber(item n1, item n2);
};
List::~List()//деструктор вынесен за класс
{
    head = tail = NULL;
}
item List::CreateMNumber(char *initStr)
{
    item number = { NULL, NULL, 0 };
    int n;
    for (n = strlen(initStr) - 1; n >= 0; n--)
    {
        AddDigit(&number, initStr[n] - '0');
    }
 
    return number;
}
void List::AddDigit(item*number, int digit)
{
    item *p = new item;
    p->digit = digit;
    p->next = p->prev = NULL;
 
    if (number->head == NULL)
    {
        number->head = number->tail = p;
    }
 
    else
    {
        number->tail->next = p;
        p->prev = number->tail;
        number->tail = p;
    }
    number->n++;
}
void List::PrintMNumber(item number)
{
    item *p = number.tail, *temp = number.tail;
 
    cout << "\nNumber: ";
 
    while (p)
    {
        if ((temp->digit == 0) && (p->prev != NULL))
        {
            temp = temp->prev;
            p = p->prev;
        }
        else
        {
            cout << p->digit;
            p = p->prev;
        }
    }
 
    free(p);
}
item List::SumMNumber(item n1, item n2)
{
    item sum = CreateMNumber("");
    item *p1 = n1.head, *p2 = n2.head;
    int digit, pos = 0, s1, s2;
 
    while (p1 || p2)
    {
        if (p1)
        {
            s1 = p1->digit;
            p1 = p1->next;
        }
 
        else s1 = 0;
 
        if (p2)
        {
            s2 = p2->digit;
            p2 = p2->next;
        }
 
        else s2 = 0;
 
        digit = (s1 + s2 + pos) % 10;
        pos = (s1 + s2 + pos) / 10;
        AddDigit(&sum, digit);
    }
 
    if (pos) AddDigit(&sum, pos);
 
    return sum;
}
void main()
{
    char *num1 = new char[1000];
    char *num2 = new char[1000];
    cout << "Enter first string (numbers): ";
    cin >> num1;
    cout << "Enter second string (numbers): ";
    cin >> num2;
    List node;
     item a = node.CreateMNumber(num1);
item     b = node.CreateMNumber(num2);
    item c = node.SumMNumber(a, b);
    node.PrintMNumber(a);
    node.PrintMNumber(b);
    cout << "\nSumm\t";
    node.PrintMNumber(c);
    cout << endl;
    getchar();
    delete[] num1;
    delete[] num2;
    system("pause");
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.03.2016, 18:17

Создание списка объектов собственного класса (SQL)
очень нужно! объясните, пожалуйста, доходчиво, а лучше с примером, как создать...

Явное создание экземпляра класса и явная специализация шаблона класса
Всем добрый день! Не могу разобраться - эти две технологии дают один и тот же...

Возможно ли создание объекта шаблонного класса в функции этого класса?
Доброго времени суток, уважаемые форумчане :) Мне по лабам задали задание -...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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