Форум программистов, компьютерный форум 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
Сообщений: 18
16.03.2016, 18:17  [ТС]     Создание класса-списка на основе кода со списком без класса
В общем помощи не дождался, сделал сам. Пользуйтесь, кому надо. Если найдете ошибки, прошу написать о них.
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");
}
 
Текущее время: 20:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru