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

Сортировка пузырьковым методом - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Точность float http://www.cyberforum.ru/cpp-beginners/thread713962.html
Объясните, пожалуйста,когда у числа типа float точность 7 цифр, а когда 8. Желательно с примером)Весь интернет облазил, ответ так и не нашел. P.S. Про экспоненту, мантиссу и т.п. неоднократно уже читал
C++ вывести на друк слово "Одинаковые" если эти массивы полностью совпадают,и слово "Разные" в противоположном случае. Создать два символьных массива по 12 элементов , и вывести на друк слово "Одинаковые" если эти массивы полностью совпадают,и слово "Разные" в противоположном случае. http://www.cyberforum.ru/cpp-beginners/thread713958.html
программа с рекурсивной функцией C++
написать программу на языке с++ решить задачу не используя операторы цикла написать программу с рекурсивной функцией вычисляющей
Перегрузить C++
#include <conio> #include <iostream> #include <stdio> using namespace std; class summa { private: double first; int second; public: summa() {};
C++ Двумерные массивы. Найти произведение элементов, расположенных между первым отрицательным числом и последним четным числом в матрице http://www.cyberforum.ru/cpp-beginners/thread713944.html
вычислить произведение элементов, расположенных между первым отрицательным числом и последним четным числом в матрице. какое условие задать(туплю)? потом все это преобразую в файлы)Правила форума п. 3.4: Избегайте использования слишком большого количества смайлов в сообщениях в тематических разделах форума, а также "кричащего" выделения текста, в том числе CAPS LOCK. Правила форума п. 5.4:...
C++ Нужно определить два класса SOS! Прошу вашей помощи. 1) Определить класс, объектами которого являются отношения на множестве целых чисел {0,1, 2, …, n-1}.Определить конструктор, аргументами которого служат либо массив пар, принадлежащих отношению, либо тройка чисел с плавающей точкой. В последнем случае отношение инициируется как состоящее из (x,y), для которых ax+by+c ≤ 0. Определить операции дополнения, пересечения,... подробнее

Показать сообщение отдельно
Diemon
17 / 5 / 2
Регистрация: 13.09.2011
Сообщений: 24
30.11.2012, 02:08
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
#include <iostream>
#include <string>
#include <algorithm>
 
int const N = 5;
 
using namespace std;
 
class book{
    public:
        book();
 
        string getAuthor() const;
        void setAuthor(string);
 
        string getName() const;
        void setName(string);
 
        int getPages() const;
        void setPages(int);
 
        bool getIsFree() const;
 
        void setNewBook();
        void printBook();
    private:
        bool isFree;
        string author;
        string name;
        int pages;
};
 
void sortBooks(class book*);
 
int main(){
    bool isInMenu = true;
    char key;
    class book arr[N];
 
    while(isInMenu){
 
        cout<<"1 to create new book \n"
            <<"2 to sort books \n"
            <<"3 to print all books \n"
            <<"4 to exit \n"
            <<"Choise: ";
        cin>>key;
        switch(key){
            case '1':
            for(int i = 0; i<N; i++){
                if(arr[i].getIsFree()){
                    arr[i].setNewBook();
                    break;
                }
                if(!arr[N-1].getIsFree()){
                    cout<<"\n There is no empty slots left! \n";
                    break;
                }
            }
            break;
 
            case '2':
                sortBooks(arr);
            break;
 
            case '3':
                for(int i = 0; i<N; i++)
                    if(!arr[i].getIsFree())
                        arr[i].printBook();
                break;
 
            case '4':
                isInMenu = false;
                break;
 
        }
        key=0;
        cout<<"\n\n\n\n";
    }
 
 
    return 0;
}
 
void sortBooks(class book* arr){
    string str1;
    string str2;
    for(int i = 0 ; i < N ; i++)
        for(int j = 1 ; j < N-i ; j++){
            if(!arr[j].getIsFree() && !arr[j-1].getIsFree()){
 
                str1 = arr[j-1].getName();
                str2 = arr[j].getName();
                if( str1[0] > str2[0] ){
 
                    swap(arr[j-1],arr[j]);
                    break;
                }
                for(int k = 0; k < str1.size() ; k++){
 
                    if( str1[k] > str2[k] ){
                        swap(arr[j-1],arr[j]);
                        break;
                    }
                }
            }
        }
}
 
book::book(){
    isFree = true;
}
 
void book::setNewBook(){
    cout<<endl<<"Enter author: ";
    cin>>author;
    cout<<endl<<"Enter name: ";
    cin>>name;
    cout<<endl<<"Enter number of pages: ";
    cin>>pages;
    isFree = false;
}
 
void book::setAuthor(string newAuthor){
    author = newAuthor;
}
 
void book::setName(string newName){
    name = newName;
}
 
void book::setPages(int newPages){
    pages = newPages;
}
 
bool book::getIsFree() const{
    return isFree;
}
 
string book::getAuthor() const{
    return author;
}
 
string book::getName() const{
    return name;
}
 
int book::getPages() const{
    return pages;
}
 
void book::printBook(){
    cout<<"\n Author: "<<author
        <<"\n Name: "<<name
        <<"\n Pages: "<<pages;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru