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

Найти ошибку - C++

Восстановить пароль Регистрация
 
qwestcl
10 / 10 / 1
Регистрация: 30.09.2012
Сообщений: 172
24.02.2014, 18:17     Найти ошибку #1
C++ (Qt)
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
HugeInteger::HugeInteger() {
    for (int i = 0; i <sizeArray; ++i) {
        array[i] = rand()%10;
    }
}
void HugeInteger::sumOfHugeInteger(HugeInteger hugeTwo) {
    int sumOfInteger[sizeArray + 5] = {0};
    int sizeSumArray = 0;
 
    for (int i = sizeArray - 1; i >= 0; --i) {
        if (array[i] + hugeTwo.returnNum(i) >= 10) {
            sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10;
            sizeSumArray++;
            sumOfInteger[sizeSumArray] += 1;
        }
        else {
            sumOfInteger[sizeSumArray] += array[i] + hugeTwo.returnNum(i);
            sizeSumArray++;
        }
    }
 
    if(sumOfInteger[sizeSumArray])
        cout << sumOfInteger[sizeSumArray];
    for (int i = sizeSumArray - 1; i >= 0; i--) {
        cout << sumOfInteger[i];
    }
    cout << endl;
}
Результат виден на приложенных файлах. что я не так сделал?
Миниатюры
Найти ошибку   Найти ошибку  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.02.2014, 18:17     Найти ошибку
Посмотрите здесь:

найти слова повторяющиеся более одного раза, не могу найти ошибку C++
C++ Массивы. Посчитать количество положительных, найти минимальное, удалить строку с минимальным (Не могу найти ошибку)
C++ Массивы. Найти среднее арифметическое элементов массива, расположенных до максимального элемента (найти ошибку в задании)
найти ошибку(в одномерном массиве найти количество различных элементов) C++
C++ В строках матрицы с отрицательным элементом на главной диагонали найти наибольший из всех элементов (найти ошибку в коде)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Amandosov
Знаток
156 / 156 / 65
Регистрация: 18.11.2012
Сообщений: 411
Записей в блоге: 2
24.02.2014, 18:43     Найти ошибку #2
Цитата Сообщение от qwestcl Посмотреть сообщение
for (int i = sizeArray - 1; i >= 0; --i) {
* * * * if (array[i] + hugeTwo.returnNum(i) >= 10) {
* * * * * * sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10;
* * * * * * sizeSumArray++;
* * * * * * sumOfInteger[sizeSumArray] += 1;
* * * * }
* * * * else {
* * * * * * sumOfInteger[sizeSumArray] += array[i] + hugeTwo.returnNum(i);
* * * * * * sizeSumArray++;
* * * * }
* * }
Надо заменить условию
C++
1
if (array[i] + hugeTwo.returnNum(i)+ sumOfInteger[sizeSumArray]>= 10)
qwestcl
10 / 10 / 1
Регистрация: 30.09.2012
Сообщений: 172
24.02.2014, 18:58  [ТС]     Найти ошибку #3
к сожалению, ничего не изменилось.
Миниатюры
Найти ошибку  
Ev_Hyper
 Аватар для Ev_Hyper
1806 / 1627 / 435
Регистрация: 15.12.2013
Сообщений: 5,781
24.02.2014, 19:03     Найти ошибку #4
qwestcl, вы не могли бы пояснить, что не так на скриншоте из поста:
Найти ошибку
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
24.02.2014, 19:16     Найти ошибку #5
А если так:
C++
1
2
3
4
5
6
7
8
9
10
void HugeInteger::sumOfHugeInteger(HugeInteger hugeTwo) {
    int sumOfInteger[sizeArray + 5] = {0};
    int sizeSumArray = 0;
    int one(0);
    for (int i = sizeArray - 1; i >= 0; --i) {
 
            sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10+one;
            one=(array[i] + hugeTwo.returnNum(i)) / 10;
        }
....
qwestcl
10 / 10 / 1
Регистрация: 30.09.2012
Сообщений: 172
24.02.2014, 19:17  [ТС]     Найти ошибку #6
Ev_Hyper, Простите, не верно отобразил суть. Результат должен равняться 892563742730393087018451065896,а у меня: 892563742731039308710184511065896
Тамика
Котовчанин
 Аватар для Тамика
859 / 439 / 129
Регистрация: 16.02.2010
Сообщений: 2,538
Записей в блоге: 27
24.02.2014, 19:20     Найти ошибку #7
Я когда-то писала перегрузку операций для своего класса BigNumbers. Можете переделать под свои имена. Вдруг получится.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
BigNumber BigNumber::operator+ (BigNumber& b)
{
    BigNumber result(*this);
    int temp=0;
    int k;
    for(int i = 0; i < max (b.num1.size(), (*this).num1.size()); i ++)
    {
        k = ( i < result.num1.size() ? result.num1[i] : 0) + temp + ( i < b.num1.size() ? b.num1[i] : 0);
        i < num1.size() ? result.num1[i] = k % 10 : result.num1.push_back(k % 10);
        temp = k / 10;
    }
    if( k >= 10)
        result.num1.push_back(temp);
return result;
}
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
24.02.2014, 19:23     Найти ошибку #8
Ошибся я вот так скорее:
C++
1
2
3
4
5
6
7
8
9
10
11
12
void HugeInteger::sumOfHugeInteger(HugeInteger hugeTwo) {
    int sumOfInteger[sizeArray + 5] = {0};
    int sizeSumArray = 0;
    int one(0);
    for (int i = sizeArray - 1; i >= 0; --i) {
 
            sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10;
            one=(array[i] + hugeTwo.returnNum(i)) / 10;
            sizeSumArray++;
            sumOfInteger[sizeSumArray]=one;
        }
....
qwestcl
10 / 10 / 1
Регистрация: 30.09.2012
Сообщений: 172
24.02.2014, 19:47  [ТС]     Найти ошибку #9
Ничего не изменилось :'(
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
24.02.2014, 19:51     Найти ошибку #10
Выложи полностью код, не хочу донабирать
qwestcl
10 / 10 / 1
Регистрация: 30.09.2012
Сообщений: 172
24.02.2014, 19:54  [ТС]     Найти ошибку #11
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
#ifndef MYHUGEINTEGER_H
#define MYHUGEINTEGER_H
 
#include <windows.h>
#include <iostream>
#include <time.h>
 
using namespace std;
 
const int sizeArray = 30;
 
class HugeInteger {
public:
    HugeInteger();
    void printNum();
    void sumOfHugeInteger(HugeInteger);
    int returnNum(int);
private:
    int array[sizeArray];
};
 
HugeInteger::HugeInteger() {
    for (int i = 0; i <sizeArray; ++i) {
        array[i] = rand()%10;
    }
}
 
void HugeInteger::printNum() {
    int i = 0;
 
    while (!array[i])
        i++;
    for (; i < sizeArray; ++i)
        cout << array[i];
 
    cout << endl;
}
 
int HugeInteger::returnNum(int i) {
    return array[i];
}
 
void HugeInteger::sumOfHugeInteger(HugeInteger hugeTwo) {
    int sumOfInteger[sizeArray + 5] = {0};
    int sizeSumArray = 0;
    int one(0);
 
    for (int i = sizeArray - 1; i >= 0; --i) {
//        if ((array[i] + hugeTwo.returnNum(i) + sumOfInteger[sizeSumArray]) >= 10) {
//            sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10;
//            sizeSumArray++;
//            sumOfInteger[sizeSumArray] += 1;
//        }
//        else {
//            sumOfInteger[sizeSumArray] += array[i] + hugeTwo.returnNum(i);
//            sizeSumArray++;
//        }
        sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10;
                    one=(array[i] + hugeTwo.returnNum(i)) / 10;
                    sizeSumArray++;
                    sumOfInteger[sizeSumArray]=one;
    }
 
    if(sumOfInteger[sizeSumArray])
        cout << sumOfInteger[sizeSumArray];
    for (int i = sizeSumArray - 1; i >= 0; i--) {
        cout << sumOfInteger[i];
    }
    cout << endl;
}
 
#endif // MYHUGEINTEGER_H
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include "myHugeInteger.h"
#include <windows.h>
#include <time.h>
 
using namespace std;
 
int main()
{
    srand(time(NULL));
 
    HugeInteger hugeOne;
    HugeInteger hugeTwo;
 
    cout << "hugeOne: ";
    hugeOne.printNum();
    cout << "hugeTwo: ";
    hugeTwo.printNum();
    cout << "sumHuge: ";
    hugeOne.sumOfHugeInteger(hugeTwo);
 
    return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.02.2014, 20:15     Найти ошибку
Еще ссылки по теме:

C++ Найти сумму первых n-четных натуральных чисел (найти ошибку)
C++ Помогите найти ошибку: По двум сторонам и углу найти все остальное

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

Или воспользуйтесь поиском по форуму:
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
24.02.2014, 20:15     Найти ошибку #12
Вот так
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
void HugeInteger::sumOfHugeInteger(HugeInteger hugeTwo) {
    int sumOfInteger[sizeArray + 5] = {0};
    int sizeSumArray = 0;
    int one(0);
 
    for (int i = sizeArray - 1; i >= 0; --i) {
//        if ((array[i] + hugeTwo.returnNum(i) + sumOfInteger[sizeSumArray]) >= 10) {
//            sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10;
//            sizeSumArray++;
//            sumOfInteger[sizeSumArray] += 1;
//        }
//        else {
//            sumOfInteger[sizeSumArray] += array[i] + hugeTwo.returnNum(i);
//            sizeSumArray++;
//        }
    
        sumOfInteger[sizeSumArray] += (array[i] + hugeTwo.returnNum(i)) % 10;
        if (sumOfInteger[sizeSumArray]==10) {
            sumOfInteger[sizeSumArray]=0;
            one=1;
        }else  one=(array[i] + hugeTwo.returnNum(i)) / 10;
                    sizeSumArray++;
                    sumOfInteger[sizeSumArray]+=one;
    }
 
    if(sumOfInteger[sizeSumArray])
        cout << sumOfInteger[sizeSumArray];
    for (int i = sizeSumArray - 1; i >= 0; i--) {
        cout << sumOfInteger[i];
    }
    cout << endl;
}
Yandex
Объявления
24.02.2014, 20:15     Найти ошибку
Ответ Создать тему
Опции темы

Текущее время: 11:29. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru