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

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

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

Показать сообщение отдельно
awashwinter
0 / 0 / 0
Регистрация: 05.10.2015
Сообщений: 16
14.03.2016, 19:32     Создание класса-списка на основе кода со списком без класса
Здравствуйте. Не могли бы вы показать, как оформить этот код в виде класса. Смысл задания: это засунуть в список большое число(здесь я разбираю строку и преобразую поцифренно в список), засунуть еще одно число в другой список и сложить эти числа (грубо говоря сумма в столбик).
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);
}
Заранее спасибо.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:51. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru