Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Алгоритм Крусуала http://www.cyberforum.ru/cpp-beginners/thread1684922.html
Всем доброго времени суток. Хочу реализовать метод алгоритма Краскала, он принимает единственное поле класса вложенный вектор векторов, он отображает матрицу смежности этого графа. Метод должен...
C++ Упорядочение столбцов методом - выбора по значению первого элемента Здравствуйте, помогите сделать сортировку. Мне надо переставить столбцы по значению их самого верхнего элемента . Мой код перемещает только первую строку . void choicesSort() // сортировка выбором... http://www.cyberforum.ru/cpp-beginners/thread1684920.html
Что нужно изменить? C++
Помогите пожалуйста разобраться, что в представленном ниже коде нужно изменить, чтобы полученная программа соответствовала моему варианту? Представленный вариант: Функция с переменным числом...
Двоичный поиск теперь отлично справляется, вот очень хороший пример для двоичного поиска C++
Упорядоченная структура по среднему балу. Надо сделать поиск по значению среднему балу 3.2 #include <iostream> #include <windows.h> #include <cstdlib> using namespace std; struct structura {...
C++ В заданном диапазоне чисел найти все сочетания цифр без повторений http://www.cyberforum.ru/cpp-beginners/thread1684899.html
Доброго времени суток! Помогите исправить код программы.Вот задание: Для заданных m и n найти все сочетания по m из чисел 1,2,...,n, без повторений.К примеру вводим n=4,m=2, на выходе должны получить...
C++ Даны натуральное число n, действительные числа 1,2,3,4,5,6. вычислить можно на mathematica или на другом языке a1^2,a1*a2,.....,a1*an подробнее

Показать сообщение отдельно
awashwinter
0 / 0 / 0
Регистрация: 05.10.2015
Сообщений: 19

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

14.03.2016, 19:32. Просмотров 190. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru