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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Работа с файлами. Как добавить переход на новую строку при записи? http://www.cyberforum.ru/cpp-beginners/thread1212419.html
Задача такая, дан текстовый файл (с информацией о людях Фамилия Имя Отчество) и надо создать второй файл с записями вида «Фамилия И.О.», например, «Иванов В.С.». Вопрос, моя программа делает то что нужно, а как так сделать чтобы в другой файл записывалось Фамилия И.О. с новой строки? Или не правильно сделал прогарамму? Каверников Михаил Александрович Иванов Павел Андреевич Иванов Виктор...
C++ Перегрузка оператора присваивания Вот есть такой класс template<typename TT> class Matrix { public: //====================================================================================================== Matrix<TT>(int Row, int Col) { RowCount = Row; ColCount = Col; http://www.cyberforum.ru/cpp-beginners/thread1212410.html
Как создать структуру-список, поля которой — ссылка на такую же структуру C++
Суть вопроса в том, как создать структуру-список, поля которой - ссылка на сл. элемент(такую же структуру) и ссылка на объект, относящийся к любому из классов. Проще говоря - список из объектов, относящихся к разным классам.
Правильно ли я реализовываю класс длинной арифметики? C++
class LongLong { private: char * longNumber; int _size; public: LongLong(const char *number = NULL); LongLong(unsigned int); friend LongLong operator +(const LongLong &, const LongLong &);
C++ Структура "Массив" http://www.cyberforum.ru/cpp-beginners/thread1212371.html
Определить количество каждой цифры в числе ( массив из трех чисел) . Нужно использовать структуру для сохранения элемента массива и количества разных чисел в нем. К сожалению в структурах я ничего не понимаю:cry:. Задачу сделала, но без использования структуры. Если кто то может , переделайте пожалуйста так, что бы была использована структура. Буду очень багодарна:) #include "stdafx.h"...
C++ Определить скалярное произведение строки и столбца, где расположен максимальный "особый" элемент Дан двумерный массив А(N,N) натуральных чисел. Элемент A(I,J) назовем особым, если оно является палиндромом, то есть одинаково читается слева - направо и наоборот. Определить скалярное произведение строки и столбца, где расположен максимальный особый элемент. И есть еще вторая задачка: Составить на языке С/С++ программу. Используя функции и режим меню, создать двоичный файл из... подробнее

Показать сообщение отдельно
Serj123
1 / 1 / 0
Регистрация: 30.05.2014
Сообщений: 49
19.06.2014, 17:14     Правильно ли я реализовываю сложение чисел в длинной арифметике?
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
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;
}
 
 
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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru