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

Разработать класс для представления вещественный чисел... - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Редактирование текстового файла http://www.cyberforum.ru/cpp-beginners/thread419576.html
Привет всем!)Помогите...впервые пишу на С++,и возникла проблема..я записываю в файл данные о книге...Затем по заданию мне нужно отредактировать файл - то есть изменить информацию об определенной книге,ввожу ее номер,начинаю изменять..и тут проблема..как это сделать..я попытался(функция void izm),но не выходит..Вот текст проги: #include "stdafx.h" #include "stdio.h" #include "string.h"...
C++ Удалить из строки слова, состоящие только из прописных букв Работа со строками (С) Дана строка символов, состоящая из прописных и строчных латинских букв и пробелов. Группы символов, разделенные пробелами (одним или несколькими) и не содержащие пробелов внутри себя, будем называть словами. Удалить из строки слова, состоящие только из прописных букв. Вывести на печать полученную строку и количество удаленных слов. как можно проще на си http://www.cyberforum.ru/cpp-beginners/thread419570.html
Найти и напечатать все слова, которые заканчиваются на заданный символ C++
Помогите пожалуйста кто может. Очень прошу. :cry: Сдать в четверг нужно... Дано предложение, в котором слова разделены любым количеством пробелов, а общая длинна <=80. Найти и напечатать все слова, которые заканчиваются на заданную букву. Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
Найти минимум функции методом дихотомии. C++
Помогите пожалуйста кто может. Очень прошу. :cry: Сдать в четверг нужно... Найти минимум функции (х^2)+(e^-2) методом дихотомии. Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
C++ Подсчет суммы элементов в матрице http://www.cyberforum.ru/cpp-beginners/thread419564.html
Помогите пожалуйста кто может. Очень прошу. :cry: Сдать в четверг нужно... Дана матрица А(N,M), которая вводится из файла и число К, вводимое с клавиатуры. В к-ой строке найти максимальный элемент. В том столбце где этот элемент находится. Найти сумму положительных элементов. Каждый этап решать при помощи подпрограммы, работающей с вектором. Вектор "вырезать" из матрицы. Запрещено создавать...
C++ Метод списка swap, который меняет информацию двух узлов местами Добавьте в класс списков метод Swap(int i, int j), меняющую информацию звеньев списка с номерами i и j прошу,помогите,пожалуйста подробнее

Показать сообщение отдельно
DebieCooper
 Аватар для DebieCooper
34 / 34 / 1
Регистрация: 12.10.2011
Сообщений: 285
28.12.2011, 12:29     Разработать класс для представления вещественный чисел...
Разработать класс для представления вещественных чисел, задаваемыъ тройкой целых чисел (целая часть числа, дробная часть числа, кол-во цифр в дробной части). Максимальное число цифр в дробной части - 5.

Пример: 12.00341 = (12,341,5)
Класс должен включать весь необходимый интерфейс: конструкторы, перегрузку операций (в том числе +=, +, ++, -=, -, =, <, <=, ==), другие необходимые методы. На множестве троек чисел отношение < является отношением лексикографического порядка.

Текстовая программа должна продемонстрировать выполнение последовательности операций сложения и вычитания обьектов класса и чисел, а также выполнение операций присваивания для различных типов операндов.

Кроме того, необходимо реализовать функцию, которая в массиве находит пару соседних обьектов, находящихся в отношении < (если такая пара существует). Далее, необходимо найти сумму элементов массива, меньших заданного значения.
Помогите плиз, Итоговая контрольная.

Добавлено через 41 минуту
Вот очень похожий код, но не знаю как переделать под свою задачу.
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
#include <iostream>  
 using namespace std;  
 class chisla
{
private:
 int a;
 int b;
 int c;
public:
 chisla(): a(0), b(0),c(0)
 {}
 chisla(int x): a(x), b(0),c(0)
 {}
 chisla(int x, int y,int z)
 {
  a=x;
  b=y;
  if (z<6&&z>=0)
  c=z;
  else{
   cout << "ERROR!" << endl << "3ht element mast be >6 and >=0" << endl;
   exit(1);
  }
 }
 chisla operator+ (chisla t)const;
 chisla operator- (chisla t)const;
 chisla operator* (chisla t)const;
 chisla operator/ (chisla t)const;
 
 chisla operator= (chisla t){
 a=t.a;
 b=t.b;
 c=t.c;
 return (*this);}
 chisla operator= (int t)
 {
 a=t;
 b=0;c=0;
 return (*this);}
 chisla operator= (float t) {
 a=t;
 b=(t-a)*100000;c=5;
 return (*this);}
 chisla operator= (double t) {
 a=t;
 b=(t-a)*100000;c=5;
 return (*this);}
 
 chisla operator+= (chisla t);
 chisla operator-= (chisla t);
 chisla operator*= (chisla t);
 chisla operator/= (chisla t);
 
 bool operator< (chisla t)const;
 bool operator> (chisla t)const;
 bool operator<= (chisla t)const;
 bool operator>= (chisla t)const;
 bool operator== (chisla t)const;
 
 friend chisla & operator ++ (chisla &t);
 chisla operator ++(int){
 chisla t(*this);
 a++;
 return t;}
 friend chisla &operator -- (chisla &t);
 chisla operator --(int){
 chisla t(*this);
 a--;
 return t;}
 
 friend istream& operator >> (istream& s, chisla& t);
 friend ostream& operator << (ostream& s, chisla& t);
};
chisla chisla::operator+ (chisla t)const{
 int x, y,z=5;
 int y1=b,y2=t.b;
 x = a+t.a;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
    y=y1+y2;
 return chisla(x, y,z);
}
chisla chisla::operator- (chisla t)const{
 int x, y,z=5;
 int y1=b,y2=t.b;
 x = a-t.a;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
    y=y1-y2;
 return chisla(x, y,z);
}
chisla chisla::operator* (chisla t)const{
 int x, y,z=5;
 int y1=b,y2=t.b;
 double s1,s2,s3;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
  s3=s1*s2;
  x=s3;
  y=(s3-x)*100000;
 return chisla(x, y,z);
}
chisla chisla::operator/ (chisla t)const{
 int x, y,z=5;
 int y1=b,y2=t.b;
 double s1,s2,s3;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
  s3=s1/s2;
  x=s3;
  y=(s3-x)*100000;
 return chisla(x, y,z);
}
 
chisla chisla::operator+= (chisla t){
 int x, y,z=5;
 int y1=b,y2=t.b;
 x = a+t.a;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
 y=y1+y2;
 return chisla(x, y,z);
}
chisla chisla::operator-= (chisla t){
 int x, y,z=5;
 int y1=b,y2=t.b;
 x = a-t.a;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
    y=y1-y2;
 return chisla(x, y,z);
}
chisla chisla::operator*= (chisla t){
 int x, y,z=5;
 int y1=b,y2=t.b;
 double s1,s2,s3;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
  s3=s1*s2;
  x=s3;
  y=(s3-x)*100000;
 return chisla(x, y,z);
}
chisla chisla::operator/= (chisla t){
 int x, y,z=5;
 int y1=b,y2=t.b;
 double s1,s2,s3;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
  s3=s1/s2;
  x=s3;
  y=(s3-x)*100000;
 return chisla(x, y,z);
} 
bool chisla::operator< (chisla t)const{
 int y1=b,y2=t.b;
 double s1,s2;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
 return (s1-s2 < 0); 
}
bool chisla::operator> (chisla t)const{
 int y1=b,y2=t.b;
 double s1,s2;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
 return (s1-s2 > 0); 
}
bool chisla::operator<= (chisla t)const{
 int y1=b,y2=t.b;
 double s1,s2;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
 return (s1-s2 <= 0); 
}
bool chisla::operator>= (chisla t)const{
 int y1=b,y2=t.b;
 double s1,s2;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
 return (s1-s2 >= 0); 
}
bool chisla::operator== (chisla t)const{
 int y1=b,y2=t.b;
 double s1,s2;
 for(int i=5-c;i>0;i--)
     y1=y1*10;
  for(int i=5-t.c;i>0;i--)
     y2=y2*10;
  s1=a+y1/100000;
  s2=t.a+y2/100000;
 return (s1-s2 == 0); 
}
istream& operator >> (istream& s, chisla& t){
    s>> t.a>>t.b>>t.c;
  return s;
}
 ostream& operator << (ostream& s, chisla& t){
     s <<"("<< t.a<<","<<t.b<<","<<t.c<<")";
  return s;
 }
 chisla & operator ++ (chisla &t){
 ++t.a;
 return t;}
 chisla &operator -- (chisla &t){
 --t.a;
 return t;}
 void main(){
     setlocale(LC_ALL,"rus");
chisla value1; 
chisla value2; 
cin>>value1>>value2;
cout<<value1 << " " << value2 << endl;
cout<<value1 + value2 << endl; 
cout<<value1 - value2 << endl;  
cout<<value1 * value2 << endl;   
cout<<value1 / value2 << endl;  
value1= value2;  
cout << value1 << " = " << value2 << endl;  
cout << value1 << " + " << value2 <<"="<<value1+value2<< endl;  
cout << value1 << " +1" << (value1+1) << endl;  
value1=1.25;
cout << value1 << endl;  
system("pause");
 }
Добавлено через 13 минут
Апну темку.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:55. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru