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

Вычисления до заданной точности - C++

Восстановить пароль Регистрация
 
Аркалык
13 / 13 / 4
Регистрация: 24.09.2013
Сообщений: 138
18.12.2013, 13:20     Вычисления до заданной точности #1
Вычисления до заданной точности
Исправьте ошибку пожалуйста!
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 <stdio.h>
#include <math.h>
#include <conio.h>
 
int fact(int x)
{
if(x<=1) return 1;
return x*fact(x-1);
}
int main()
{
clrscr();
    float v, s = 0;
    float eps = .0001f;
    for ( int i = 1; ; i++ )
    {
    v = 1.0+1.f /fact(i);
    if ( v < eps ) break;
    s += v;
    }
    printf( "%f\n", s );
    getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.12.2013, 13:20     Вычисления до заданной точности
Посмотрите здесь:

Вычислить сумму ряда. Вычисления заканчивать при достижении заданной степени точности C++
C++ Табулировать функции F и S при заданной точности E, с указанным шагом и диапазоном значений по x:
C++ Табулировать функции F и S при заданной точности E, с указанным шагом и диапазоном значений по x:
C++ Не точности вычисления C++
Вывести число итераций, необходимое для достижения заданной точности C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
SatanaXIII
Супер-модератор
Эксперт С++
 Аватар для SatanaXIII
5547 / 2561 / 233
Регистрация: 01.11.2011
Сообщений: 6,330
Завершенные тесты: 1
18.12.2013, 13:35     Вычисления до заданной точности #2
Зачем вы в семнадцатой строке постоянно единицу прибавляете? Один раз ее перед циклом внесите и более не надо.
Аркалык
13 / 13 / 4
Регистрация: 24.09.2013
Сообщений: 138
18.12.2013, 13:50  [ТС]     Вычисления до заданной точности #3
SatanaXIII, Вот так, но ошибка не в этом, не компилируется код (пишу на турбо си):
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 <stdio.h>
#include <math.h>
#include <conio.h>
 
int fact(int x)
{
if(x<=1) return 1;
return x*fact(x-1);
}
int main()
{
clrscr();
    float v,p=1.0, s = 0;
    float eps = .0001f;
    for ( int i = 1; ; i++ )
    {
    v = p+1.f /fact(i);
    if ( v < eps ) break;
    s += v;
    }
    printf( "%f\n", s );
    getch();
}
SatanaXIII
Супер-модератор
Эксперт С++
 Аватар для SatanaXIII
5547 / 2561 / 233
Регистрация: 01.11.2011
Сообщений: 6,330
Завершенные тесты: 1
18.12.2013, 13:55     Вычисления до заданной точности #4
Вычислить бесконечную сумму рда с заданной точностью e
Вычислить бесконечную сумму ряда с заданной точностью e (e>0)
Вычислить с точностью ε сумму и указать количество учтенных слагаемых
Аркалык
13 / 13 / 4
Регистрация: 24.09.2013
Сообщений: 138
18.12.2013, 13:58  [ТС]     Вычисления до заданной точности #5
SatanaXIII, К сожалению это не ответ
SatanaXIII
Супер-модератор
Эксперт С++
 Аватар для SatanaXIII
5547 / 2561 / 233
Регистрация: 01.11.2011
Сообщений: 6,330
Завершенные тесты: 1
18.12.2013, 14:13     Вычисления до заданной точности #6
Цитата Сообщение от Аркалык Посмотреть сообщение
не компилируется код
Приведите текст ошибки.
Аркалык
13 / 13 / 4
Регистрация: 24.09.2013
Сообщений: 138
18.12.2013, 14:27  [ТС]     Вычисления до заданной точности #7
SatanaXIII, Написал на Dev C++, компилируется, но нет результата. Походу не хватает мощности пк для вычисление :
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include<iostream>
#include<cmath>
using namespace std;
 
float fact(float x)
{
if(x<=1) return 1;
return x*fact(x-1);
}
int main()
{
    float v,p=1.f, s = 0;
    float eps = .0001f;
    for ( int i = 1; ; i++ )
    {
    v = p+1.f /fact(i);
    if ( v < eps ) break;
    s += v;
    }
cout<<s;
system("pause");
}
SatanaXIII
Супер-модератор
Эксперт С++
 Аватар для SatanaXIII
5547 / 2561 / 233
Регистрация: 01.11.2011
Сообщений: 6,330
Завершенные тесты: 1
18.12.2013, 14:45     Вычисления до заданной точности #8
Цитата Сообщение от Аркалык Посмотреть сообщение
не хватает мощности пк для вычисление
А. Ну что-то я сразу не подумал. Извините, что мурыжу тут вас уже пол дня. Вот так должно быть с учетом оптимизации под вашу архитектуру процессора (там просто за счет дублирования регистров s переназначается с v и на кеше третьего уровня (который под расчет с плавающей точкой) шине адреса не хватает разрядности, чтобы протолкнуть все число за раз):
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
#include<iostream>
#include<cmath>
 
using namespace std;
 
 
float fact(float x)
{
if(x<=1) return 1;
return x*fact(x-1);
}
 
 
int main()
{
    float v=1, s = 0;
    float eps = .0001f;
    for ( int i = 1; ; i++ )
    {
    v = v + 1.f /fact(i);
    if ( 1.f /fact(i) < eps ) break;
    s += v;
    }
cout<<s;
system("pause");
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.12.2013, 15:15     Вычисления до заданной точности
Еще ссылки по теме:

C++ Проверить вычисления на переполнение и потерю точности
Программа должна показать все комбинации заданной суммы чисел заданной точности C++
C++ Вывести число итераций, необходимое для достижения заданной точности

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

Или воспользуйтесь поиском по форуму:
Аркалык
13 / 13 / 4
Регистрация: 24.09.2013
Сообщений: 138
18.12.2013, 15:15  [ТС]     Вычисления до заданной точности #9
SatanaXIII, Спасибо вам Большое!!!
Yandex
Объявления
18.12.2013, 15:15     Вычисления до заданной точности
Ответ Создать тему
Опции темы

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