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

Исключения. Проверка на правильность введения целого числа - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Подсчитать количество населения в селах http://www.cyberforum.ru/cpp-beginners/thread894798.html
8.Дан список населенных пунктов области с описанием: название, кол-во жителей, тип. Тип выбирается из списка: город, районный цент, село, поселок городского тип. Подсчитать кол-во населения в селах. #include <iostream> #include <clocale> #include <stdio.h> #include <conio.h> #include <string> using namespace ::std struct Naselpunkt {
C++ Составить блок схему ,пжл ! Дан текстовый файл. Перепишите его в выходной файл, удалив все знаки препинания - программа работает , помогите оставшееся прокомментировать, и составить блок схему #include "stdafx.h" //Подкл. файлы для компиляции #include <iostream> // Подключает потоковый в/в #include <fstream> // Подключает потоковый в/в файлов #include <string.h> int main() { http://www.cyberforum.ru/cpp-beginners/thread894786.html
Определить радиус и центр окружности минимального радиуса, проходящей хотя бы через три различные точки заданного множества точук на плоскости C++
Определить радиус и центр окружности минимального радиуса, проходящей хотя бы через три различные точки заданного множества точук на плоскости.
Ошибка в коде.Удаление пробелов C++
Вот пытаюсь сделать так,чтобы между словами был только 1 пробел. Что не так с выводом и в чём моя ошибка? #include <iostream> #include <conio.h> #include <string.h> #include <string> using namespace std; int main() { char str,str2,s1;
C++ Сформировать динамический массив из элементов структурного типа http://www.cyberforum.ru/cpp-beginners/thread894760.html
1.Сформировать динамический массив из элементов структурного типа. struct реrson { char*name; char *adres; int age; }; 2.Вывести сформирован массив.
C++ Из заданного на плоскости множества точек выбрать три различные точки Из заданного на плоскости множества точек выбрать три различные точки так, чтобы разность между площадью круга, ограниченного окружностью, проходящей через эти три точки, и площадью треугольника с вершинами в этих точках была минимальной. подробнее

Показать сообщение отдельно
o33ik
138 / 5 / 1
Регистрация: 25.03.2013
Сообщений: 228
07.06.2013, 20:19     Исключения. Проверка на правильность введения целого числа
Надо сделать в программе несколько исключений. Одно из них должно срабатывать если вместо числа(int) будет введено число с точкой(float, double) или вообше символ. Исключение в принципе есть, надо токо условие для throw написать(строчки 40 и 44). Я понятия неимею как ето проверить, и сделать так чтоб програма не вылетала.

Кликните здесь для просмотра всего текста
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
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
#include <iostream>
#include <conio.h>
#include <string.h>
 
using namespace std;
 
class RD
{
    int c, z;
    public:
    class Zero_Error{};
    class Operator_Error{};
    class Numb_Error{};
    friend int gcd(RD);
    friend RD skorot(RD);
    friend void print(RD);
 
    RD::RD(void)
    {
        c=z=0;
    } 
    RD::RD(int _c, int _z)
    {
        c=_c; z=_z;
    }
    RD::RD(int _c)
    {
        c=_c; z=1;
    } 
    RD::RD(RD& t)
    {
        c=t.c; z=t.z;
    } 
    RD::~RD(){} 
 
    void input()
    {
        cout << "Enter nominator: ";
        cin >> c;
        if ()
            throw Numb_Error();
        cout << "Enter denominator: ";
        cin >> z;
        if ()
            throw Numb_Error();
        if (z == 0)
            throw Zero_Error();
    }
 
    void print()
    {
        cout << endl << "      " << c << endl << "      -" << endl << "      " << z << endl;
    }
 
    void print_one()
    {
        cout << c << endl;
    }
 
    ////////////////////////////////////////////////////////////////////
    void oper(RD a, RD b, char* key)
    {
        
        {
            RD RES;
 
            if(strcmp(key, "+")==0)
                {
                    RES = a + b; 
                    RES.print();
                }
            //
            if(strcmp(key, "-")==0)
                {
                    RES = a - b; 
                    RES.print();
                }
            //
            if(strcmp(key, "*")==0)
                {
                    RES = a * b; 
                    RES.print();
                }
            //
            if(strcmp(key, "/")==0)
                {
                    RES = a / b; 
                    RES.print();
                }
            ///////////////////////////////////////
            if(strcmp(key, ">")==0)
                {
                    if (a > b)
                        cout << "YES";
                    else
                        cout << "NO";
                }
            //
            if(strcmp(key, "<")==0)
                {
                    if (a < b)
                        cout << "YES";
                    else
                        cout << "NO";
                }
            //
            if(strcmp(key, ">=")==0)
                {
                    if (a >= b)
                        cout << "YES";
                    else
                        cout << "NO";
                }
            //
            if(strcmp(key, "<=")==0)
                {
                    if (a <= b)
                        cout << "YES";
                    else
                        cout << "NO";
                }
            //
            if(strcmp(key, "==")==0)
                {
                    if (a == b)
                        cout << "YES";
                    else
                        cout << "NO";
                }
            //
            if(strcmp(key, "!=")==0)
                {
                    if (a != b)
                        cout << "YES";
                    else
                        cout << "NO";
                }
            //
        }
        
};
 
    ////////////////////////////////////////////////////////////////////
 
    RD operator+(RD);
    RD operator-(RD);
    RD operator*(RD);
    RD operator/(RD);
    bool operator>(RD);
    bool operator<(RD);
    bool operator>=(RD);
    bool operator<=(RD);
    bool operator==(RD);
    bool operator!=(RD);
};
 
RD RD::operator+(RD drib2)
{
    RD res;
    res.c = c*drib2.z + drib2.c*z;
    res.z = z * drib2.z;
    return skorot(res);
}
 
RD RD::operator-(RD drib2)
{
    RD res;
    res.c = c*drib2.z - drib2.c*z;
    res.z = z * drib2.z;
    return skorot(res);
}
 
RD RD::operator*(RD drib2)
{
    RD res; 
    res.c = c * drib2.c; 
    res.z = z * drib2.z;
    return skorot(res);
}
 
RD RD::operator/(RD drib2)
{
    RD res;
    res.c = c * drib2.z; res.z = z * drib2.c;
    return skorot(res);
}
 
bool RD::operator>(RD drib2)
{
    bool I;
    if (c*drib2.z > drib2.c*z)
        I = true;
    else
        I=false;
     return I;
}
 
bool RD::operator<(RD drib2)
{
    bool I;
    if (c*drib2.z < drib2.c*z)
        I = true;
    else
        I=false;
     return I;
}
 
bool RD::operator>=(RD drib2)
{
    bool I;
    if (c*drib2.z >= drib2.c*z)
        I = true;
    else
        I=false;
     return I;
}
 
bool RD::operator<=(RD drib2)
{
    bool I;
    if (c*drib2.z <= drib2.c*z)
        I = true;
    else
        I=false;
     return I;
}
 
bool RD::operator==(RD drib2)
{
    bool I;
    if (c*drib2.z == drib2.c*z)
        I = true;
    else
        I=false;
     return I;
}
 
bool RD::operator!=(RD drib2)
{
    bool I;
    if (c*drib2.z != drib2.c*z)
        I = true;
    else
        I=false;
     return I;
}
 
 
int gcd(RD drib)
{
  while(drib.z) drib.z^=drib.c^=drib.z^=drib.c%=drib.z;
  int C=drib.c;
  return C;
 }
 
RD skorot(RD drib)
{
    int NOD = gcd(drib);
    drib.c = drib.c / NOD;
    drib.z = drib.z / NOD;
    return drib;
}
 
void print(RD res)
{
    cout << "Result: ";
    if (res.z == 1)
        res.print_one();
    else
        res.print();
}
 
void main()
{
    char key[3];
    RD a, b;
    while(true)
    {
        try
        {
            a.input();
 
            cout << "Enter operator:  ";
            cin >> key;
            if ((strcmp(key, "+")!=0) && (strcmp(key, "-")!=0) && (strcmp(key, "*")!=0) && (strcmp(key, "/")!=0) && (strcmp(key, ">")!=0) && (strcmp(key, "<")!=0) && (strcmp(key, "<=")!=0) && (strcmp(key, ">=")!=0) && (strcmp(key, "==")!=0) && (strcmp(key, "!=")!=0))
                throw RD::Operator_Error();
 
            b.input();
 
            a.oper(a, b,key);
            cout << endl;
        }
        catch(RD::Zero_Error)//
        {
            cout << "\nError! Denominator cant be a zero!\n\n";
        }
        catch(RD::Numb_Error)
        {
            cout << "\nError! Entered invalid value!\n\n";
        }
        catch(RD::Operator_Error)//
        {
            cout << "\nError! Invalid operation!\n\n";
        }
 
        system("pause");
        system("cls");
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru