0 / 0 / 0
Регистрация: 17.10.2012
Сообщений: 38
1

Компилится на одной машине

07.12.2012, 10:07. Показов 571. Ответов 9
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
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;
}
А на других либо не компилится, либо задержки нет.
Подскажите где проблема.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.12.2012, 10:07
Ответы с готовыми решениями:

MS Access 97 и 2000 на одной машине под одной ОС: возможно?
Собствено сабж

Behavior не компилится, не хватает конструктора. Объявляю, не компилится. Не пойму
В общем, такой вот код, но не компилируется. Что не так? Чёт не пойму вообще. /// &lt;summary&gt; ...

2 версии 1с на одной машине
Могут ли стоять на одной машине 7-ю и 8-ю версии одновременно? Как это сделать?

Две ОС на одной машине
Приветствую, джентльмены!) Прошу помощи: 1. изначально стояла ХР 32 бит. 2. установил в дугой...

9
Неэпический
18098 / 10684 / 2061
Регистрация: 27.09.2012
Сообщений: 26,891
Записей в блоге: 1
07.12.2012, 10:09 2
Что значит задержки нет?
0
0 / 0 / 0
Регистрация: 17.10.2012
Сообщений: 38
07.12.2012, 10:12  [ТС] 3
черный экран появляется и пропадает сразу же:/
0
Неэпический
18098 / 10684 / 2061
Регистрация: 27.09.2012
Сообщений: 26,891
Записей в блоге: 1
07.12.2012, 10:13 4
Цитата Сообщение от ZOMBO Посмотреть сообщение
черный экран появляется и пропадает сразу же:/
при вводе 4? Или при запуске программы?
0
0 / 0 / 0
Регистрация: 17.10.2012
Сообщений: 38
07.12.2012, 10:14  [ТС] 5
при запуске.
0
Неэпический
18098 / 10684 / 2061
Регистрация: 27.09.2012
Сообщений: 26,891
Записей в блоге: 1
07.12.2012, 10:29 6
VS 2012(винда), MinGW(винда), GCC(Ubuntu) всё компилируется и работает.
0
0 / 0 / 0
Регистрация: 17.10.2012
Сообщений: 38
07.12.2012, 10:53  [ТС] 7
Помогите.
почему не работает сортировка названий по алфавиту. ;/
0
Неэпический
18098 / 10684 / 2061
Регистрация: 27.09.2012
Сообщений: 26,891
Записей в блоге: 1
07.12.2012, 11:35 8
Попробуйте поменять на:
C++
1
2
3
4
                if( arr[j-1].getName() > arr[j].getName() ){ 
                    swap(arr[j-1],arr[j]);
                    break;
                }
не проверял.
0
0 / 0 / 0
Регистрация: 17.10.2012
Сообщений: 38
07.12.2012, 11:44  [ТС] 9
это вместо какой строки?
0
Неэпический
18098 / 10684 / 2061
Регистрация: 27.09.2012
Сообщений: 26,891
Записей в блоге: 1
07.12.2012, 11:56 10
Цитата Сообщение от ZOMBO Посмотреть сообщение
это вместо какой строки?
Вместо этих:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
                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;
                    }
                }
0
07.12.2012, 11:56
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.12.2012, 11:56
Помогаю со студенческими работами здесь

Java 6 и 7 на одной машине
Здравствуйте!!! Вопрос не по программированию, но где мне ещё помогут, как не здесь? Windows XP,...

2 сайта на одной машине
Раньше попадал на мануал по поднятию двух сайтов на одной машине ... а вот сейчас чёт найти не могу...

Несколько сайтов на одной машине
Добрый день всем. Ситуация следующая: Имеются два компьютера com1 и com2. com1 выступает в...

Win7 и win8 на одной машине
Привет! Вот такая проблемка: стоит у меня на машине win8 и win7, но вот меню выбора ОС отсутствует....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru