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

Правильно ли я реализовываю класс длинной арифметики? - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Структура "Массив" http://www.cyberforum.ru/cpp-beginners/thread1212371.html
Определить количество каждой цифры в числе ( массив из трех чисел) . Нужно использовать структуру для сохранения элемента массива и количества разных чисел в нем. К сожалению в структурах я ничего не понимаю:cry:. Задачу сделала, но без использования структуры. Если кто то может , переделайте пожалуйста так, что бы была использована структура. Буду очень багодарна:) #include "stdafx.h"...
C++ Определить скалярное произведение строки и столбца, где расположен максимальный "особый" элемент Дан двумерный массив А(N,N) натуральных чисел. Элемент A(I,J) назовем особым, если оно является палиндромом, то есть одинаково читается слева - направо и наоборот. Определить скалярное произведение строки и столбца, где расположен максимальный особый элемент. И есть еще вторая задачка: Составить на языке С/С++ программу. Используя функции и режим меню, создать двоичный файл из... http://www.cyberforum.ru/cpp-beginners/thread1212359.html
C++ Создание консоли
подскажите код: менюшка: 1. вывести на экран 2. сделать тото. 3. выйти вопрос - как это реализуется в коде? чтоб меню появилось сразу, потом человек набрал пункт 1 и вывелось на экран то что просит? и соответственно если 2 - то выполнение такой то операции. спасибо.
увеличиваем число M в 2 раза и выводим текущее значение пока M<100 C++
увеличиваем число M в 2 раза и выводим текущее значение пока M<100 Помогите через цикл while полностью программу
C++ Вывести сколько и каких цифр в каждом числе http://www.cyberforum.ru/cpp-beginners/thread1212338.html
Есть массив из трех чисел , нужно вывести сколько и каких цифр в каждом числе. Программа работает только для первого числа , дальше счетчик не обнуляется. Помогите пожалуйста:cry: #include "stdafx.h" #include <iostream> int number; int i; using namespace std;
C++ N человек и прямоугольная таблица А размерностью n * n. Элемент A [i] [j] равно 1, если человек и знакома с ч n человек и прямоугольная таблица А размерностью n * n. Элемент A равно 1, если человек и знакома с человеком j, A = A . Можно ли разбить людей на две группы так, чтобы в каждой группе были только незнакомые люди. подробнее

Показать сообщение отдельно
Serj123
1 / 1 / 0
Регистрация: 30.05.2014
Сообщений: 49

Правильно ли я реализовываю класс длинной арифметики? - C++

19.06.2014, 16:39. Просмотров 129. Ответов 0
Метки (Все метки)

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
class LongLong
{
private:
char * longNumber;
int _size;
public:
LongLong(const char *number = NULL);
LongLong(unsigned int);
 
friend LongLong operator +(const LongLong &, const LongLong &);
 
~LongLong()
{
delete[] longNumber;
}
 
char *strrev(char *s) const;
 
void show()
{
for (int i = 0; i < _size; ++i)
cout << longNumber;
}
};
 
 
void reverse(char s[])
{
int i, j;
char c;
 
for (i = 0, j = strlen(s) - 1; i<j; i++, j--) {
c = s[i];
s[i] = s[j];
s[j] = c;
}
}
 
void Convert(unsigned int number, char *s)
{
 
int i = 0;
do { 
s[i++] = number % 10; 
} while ((number /= 10) > 0);
 
s[i] = '\0';
reverse(s);
}
 
LongLong::LongLong(const char *number)
{
int size = strlen(number) + 1;
_size = size;
longNumber = new char[size];
memcpy(longNumber, number, size);
}
 
LongLong::LongLong(unsigned int number)
{
int count = 0;
unsigned int a = number;
do
{
++count;
} while (a % 10 != 0);
_size = count;
longNumber = new char[count];
Convert(number, longNumber);
}
 
LongLong operator+ (const LongLong &first, const LongLong &second)
{
 
int j, d1, d2, digitsum, carry = 0,
maxlen = (first._size > second._size) ? first._size : second._size;
char *temp = new char[maxlen + 2]; assert(temp != NULL);
 
for ( j = 0; j<maxlen; j++)
{
d1 = (j > first._size - 1) ? 0 : first.longNumber[j] - '0';
d2 = (j > second._size - 1) ? 0 : second.longNumber[j] - '0';
digitsum = d1 + d2 + carry;
if (digitsum >= 10)
{
digitsum -= 10;
carry = 1;
}
else
carry = 0;
temp[j] = digitsum + '0';
}
 
if (carry)
temp[j++] = '1';
 
temp[j] = '\0';
second.strrev(temp);
LongLong result(temp);
delete[] temp;
 
return result;
}
 
char * LongLong::strrev(char *s) const
{
int len = strlen(s), len1 = len - 1, index,
limit = len >> 1;
char t;
 
for (int i = 0; i<limit; i++)
{
index = len1 - i;
t = s[index];
s[index] = s[i];
s[i] = t;
}
return s;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru