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

Не работает сортировка в методе класса - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вычислить значения функции, заданной с помощью ряда http://www.cyberforum.ru/cpp-beginners/thread739227.html
Написать программу для вычисления значения функции, заданной с помощью ряда. Вычисление ряда проводить до условия минимизации значения разности двух соседних членов ряда меньше заданного эпсилон. Вычислить значения невязки значений рядной и стандартной Windows ("math.h") функций d(сигма)=sqrt(lMyFinc(x)^2-Function(x)^2l) , проанализировать динамику изменения значения невязки в зависимости от...
C++ Объясните, пожалуйста что такой tz и тип его #include <conio.h> #include <iostream> // подключаем две библиотеки struct STUDENT // создаем структуру STUDENT с двумя параметрами (fio и оценки) { char fio; /* фамилия и.о. */ char oc; /* 5 оценок + '\n' + '\0' */ }; void main() { setlocale (LC_ALL, "Russian_Russia.1251"); //русская кодировка http://www.cyberforum.ru/cpp-beginners/thread739224.html
C++ параллельная сортировка массива
собственно задание: Параллельный алгоритм сортировки массива чисел M заключается в следующем. L параллельно работающих потока находят в своем участке массива максимальный элемент и передают его потоку – менеджеру. Поток – менеджер собирает L максимальных элементов и записывает их в массив P. Определив среди них максимальное, менеджер переписывает это значение в результирующий массив MR , и...
C++ Напишите рекурсивную функцию, которая возвращает среднее из n элементов массива чисел
!!!!!
C++ Почему код на С++ работает быстрей http://www.cyberforum.ru/cpp-beginners/thread739197.html
Не как не могу понять за счет чего код написан на С++ работает быстрей чем на C# или на других языках. На С++ работает быстрей и за того что там работаешь с памятью или как ?
C++ Builder Алгоритм Эдмондса-Карпа Всем доброго здравия. Задание такое: Задана система двусторонних дорог. Определить, можно ли закрыв какие либо три дороги, добиться того, чтобы из города А, нельзя было попасть в город В. Использую Алоритм Эдмондса-Карпа (ну как бы стараюсь использовать:)), суть такая, первоначально, после создания графа считаем что пропускная способность для всех ребер равна 1, если максимальный поток больше... подробнее

Показать сообщение отдельно
9cbka
2 / 2 / 0
Регистрация: 13.10.2012
Сообщений: 60

Не работает сортировка в методе класса - C++

20.12.2012, 02:19. Просмотров 380. Ответов 4
Метки (Все метки)

//Задание: ...Вывести список книг с фамилиями авторов в алфавитном порядке, изданных после заданного года.

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
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
#include <iostream.h>
#include <istream.h> //dlya cin.getline()
 
const int MAX = 77;
////////////////////////////////////////////////////////////////
class bibliot
{
    public:
        virtual void print()=0;
        virtual void set()=0;
};
 
////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////
class author: public bibliot
{
    protected:
        char *firstname;
        char *surname;
        char *lastname;
 
    public:
        author()
        {
            firstname=new char[MAX];
            firstname[0]='\0';
            surname=new char[MAX];
            surname[0]='\0';
            lastname=new char[MAX];
            lastname[0]='\0';
        }
 
        ~author()
        {
            delete []firstname;
            delete []surname;
            delete []lastname;
        }
 
        void set()
        {
            cout << "Vvedite imya avtora: ";
            cin >> firstname;
            cout << "Vvedite otchestvo avtora: ";
            cin >> surname;;
            cout << "Vvedite familiy avtora: ";
            cin >> lastname;
        }
 
        void print()
        {
            cout << "Avtor: " << firstname << " " 
            << surname << " " << lastname << endl;
        }
};
 
////////////////////////////////////////////////////////////////
class books: public author
{
    protected:
        unsigned int regnum;
        unsigned int impdate;
        unsigned int numpages;
        char *pubhouse;
        char *title;
 
    public:
        books():author()
        {
            pubhouse=new char[MAX];
            pubhouse[0]='\0';
            title=new char[MAX];
            title[0]='\0';
        }
 
        ~books()
        {
            delete []pubhouse;
            delete []title;
        }
 
        void set()
        {
            author::set();
            cout << "Vvedite registracionii nomer: ";
            cin >> regnum;  
            cout << "Vvedite nazvanie knigi: ";
            cin >> title;
            //cin.getline(title,MAX);
            //cout << endl;
            cout << "Vvedite god izdaniya: ";
            cin >> impdate;
            cout << "Vvedite kolichestvo stranic: ";
            cin >> numpages;
            cout << "Vvedite izdatelstvo: ";
            cin >> pubhouse;
        }
 
        void print()
        {
            author::print();
            cout << "Registracionii nomer: ";
            cout << regnum; 
            cout << "Nazvanie knigi: ";
            cout << title;
            cout << "God izdaniya: ";
            cout << impdate;
            cout << "Kolichestvo stranic: ";
            cout << numpages;
            cout << "Izdatelstvo: ";
            cout << pubhouse;
        }
 
        friend void run(books obj[], unsigned int n)
        {
            unsigned int after=0;
            unsigned int i=0, j=0;
            cout << "\nVvedite god, posle kotorogo vivodit': ";
            cin >> after;
            
            books*newobj=new books[MAX];
 
            for(i=0;i<n;i++)
            if(obj[i].impdate>after)
            {
                newobj[j++]=obj[i];
            }
 
            n=j;
            after=0;
 
            for(i=0;i<=n;i++)
            {
                for(j=i;j<=n;j++)
                {
                    if(newobj[i].lastname > newobj[i+1].lastname)
                    {
 
                        books*temp=new books;
 
                        *temp=newobj[i];
                        newobj[i]=newobj[i+1];
                        newobj[i]=*temp;
                    }
                }
 
                after++;
            }
 
            for(i=0;i<after;i++)
            {
                cout << newobj[i].title;
                cout << endl;
                cout << newobj[i].lastname;
                cout << endl;
            }
        }
};
////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////
void main()
{
    int n=0, i=0;
 
    cout << "Vvedite kolichestvo knig: ";
    cin >> n;
    cout << endl;
    
    books *obj = new books[MAX];
 
    for(i=0;i<n;i++)
    {
        obj[i].set();
        cout << endl;
    }
 
    int par=0;
 
    for(i=0;i<n;i++)
    {
        obj[i].print();
        cout << endl;
 
    }
 
    run(obj, par);
}
Добавлено через 6 минут
Неправильно работает дружественная функция run()
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 02:30. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru