0 / 0 / 0
Регистрация: 16.04.2019
Сообщений: 10
1

Вычисление значения функции с использованием рекурсии

28.05.2019, 23:30. Показов 3367. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Мне нужно вычислить значение функции (на картинке) с точностью ε (вводимой пользователем с клавиатуры) с помощью рекурсии. После преобразований у меня получилось два степенных ряда с множителями перед ними, итоговое значение равно разности сумм рядов с учетом этих множителей. Я вывела рекуррентные формулы и попробовала составить код для нахождения значения функции, но почему-то оно не совпадает с вычисленным непосредственно на калькуляторе. Вводить дополнительные переменные и присваивать им значения, равные тем, которые возвращают функции, мне пришлось, чтобы потом найти y.
Кроме того, компилятор выдаёт ошибки: "требуется точка с запятой" (после объявления функции main), "main: недопустимые локальные определения функций" и "{": не найдена несоответствующая лексема" (также в main), хотя с первой и третьей вроде всё нормально. Как можно исправить ошибки в составлении кода и сборке программы?
Помогите, пожалуйста.

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
#include "pch.h"
#include <iostream>
#include <conio.h>
#include <cstdlib>
#include <math.h>
 
using namespace std;
 
double obsch1 (double x, int n)
{
    double a1;
    if (n == 0)
    {
        a1 = 1;
        return 1;
    }
    else
    {
        a1 = obsch1(x, n - 1)*(1.5 - n)*x / n;
        return obsch1(x, n - 1)*(1.5 - n)*x / n;
    }
}
 
double sum1(double x, int n)
{
    double s1, eps;
    if (n == 0)
    {
        s1 = obsch1(x, n);
        return obsch1(x, n);
    }
    else
    {
        if (abs(obsch1(x, n)) > eps)
        {
            s1 = sum1(x, n - 1) + obsch1(x, n);
            return sum1(x, n - 1) + obsch1(x, n);
        }
        else
        {
            s1 = sum1(x, n - 1);
            return sum1(x, n - 1);
        }
    }
}
 
double obsch2(double x, int n)
{
    double a2;
    if (n == 0)
    {
        a2 = 1;
        return 1;
    }
    else
    {
        a2 = obsch2(x, n - 1)*(0.5 - n)*x / n;
        return obsch2(x, n - 1)*(0.5 - n)*x / n;
    }
}
 
double sum2(double x, int n)
{
    double s2, eps;
    if (n == 0)
    {
        s2 = obsch2(x, n);
        return obsch2(x, n);
    }
    else
    {
        if (abs(obsch2(x, n)) > eps)
        {
            s2 = sum2(x, n - 1) + obsch2(x, n);
            return sum2(x, n - 1) + obsch2(x, n);
        }
        else
        {
            s2 = sum2(x, n - 1);
            return sum2(x, n - 1);
        }
}
 
    int main()
    {
        int n;
        double x, y, s1, s2, eps;
        setlocale(LC_ALL, "Russian");
        cout << "Введите действительное число x (-1 < x < 1)";
        cin >> x;
        cout << "Введите вещественное число eps=";
        cin >> eps;
        y = 1.5*s1 - 0.5*s2;
        cout << "Значение функции y=" << y << endl;
        return 0;
    }
Изображения
 
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.05.2019, 23:30
Ответы с готовыми решениями:

Вычисление заданной функции разложением ее в ряд с использованием рекурсии
Программа вычисляет неправильно. Видимо, я что-то упустила. Не могли бы вы мне чуть-чуть...

Вычисление значения (с использованием перегрузки функции)
Добрый вечер! Составить программу для вычисления значений функции F(x) на отрезке с шагом h. ...

Вычисление значения интервально заданной функции с использованием перечисления
В Чём косяк? #include&lt;iostream&gt; int main() { typedef enum...

Вычисление значения функции в узлах табуляции с использованием циклов for, while и do ... while
Привет, задание таково:Составить программу для вычисления значения функции в узлах табуляции с...

8
7437 / 5029 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
28.05.2019, 23:37 2
AlmariNuit, поставьте после строки 81 закрывающую фигурную скобку
1
0 / 0 / 0
Регистрация: 16.04.2019
Сообщений: 10
28.05.2019, 23:47  [ТС] 3
Yetty, спасибо. Но теперь Visual Studio заметил неинициализированные локальные переменные s1, s2 и eps, хотя eps задается пользователем. Как быть с этими переменными? Я пыталась записать конечное значение y через функции sum1 и sum2, но там ещё больше ошибок выдаёт. А eps, возможно, не инициализировано в подпрограммах вычисления суммы, но ведь оно вводится с клавиатуры, тогда придётся в каждой подпрограмме опять запрашивать ввод eps. А как по-другому сделать, чтобы получить окончательное значение из всех подпрограмм, - не знаю...
0
7437 / 5029 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
28.05.2019, 23:51 4
замените #include <math.h> на #include <сmath>, а abs замените на fabs
где задаётся n ?
нет передачи eps в функцию.
Цитата Сообщение от AlmariNuit Посмотреть сообщение
Visual Studio заметил неинициализированные локальные переменные s1, s2
инициализируйте их нулём s1=0.0, s2=0.0 и передавайте в функции
1
0 / 0 / 0
Регистрация: 16.04.2019
Сообщений: 10
28.05.2019, 23:53  [ТС] 5
Yetty, попробую.
В том-то и дело, что n изначально никак не задаётся и зависит от того, с какой точностью нужно вычислить значение функции (то есть до какого члена ряда будет идти суммирование).
А как точность правильно ввести, я так и не могу понять. С помощью цикла получилось бы, а в рекурсии - не получается.
К сожалению, если s1 и s2 инициализировать нулём, то y будет равен нулю.
Не совсем понятно, как передать их в функции.
0
7437 / 5029 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.05.2019, 00:09 6
Цитата Сообщение от AlmariNuit Посмотреть сообщение
К сожалению, если s1 и s2 инициализировать нулём, то y будет равен нулю.
насчёт s1 и s2, Вы же их в функции объявляете, уберите их из строки 82 (не нужно инициализировать)
Цитата Сообщение от AlmariNuit Посмотреть сообщение
А как точность правильно ввести, я так и не могу понять.
Вы её вводите правильно, её нужно передать в функции sum1 и sum2, например
C++
1
double sum1(double x, double eps)
в строках 26 и 64 eps уберите
1
0 / 0 / 0
Регистрация: 16.04.2019
Сообщений: 10
29.05.2019, 00:11  [ТС] 7
Yetty, хорошо, а с переменной n тогда что делать, везде она "необъявленный идентификатор". Теперь только с ней выдаёт ошибки.

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
#include "pch.h"
#include <iostream>
#include <conio.h>
#include <cstdlib>
#include <cmath>
 
using namespace std;
 
double obsch1 (double x, int n)
{
    if (n == 0)
        return 1;
    else
        return obsch1(x, n - 1)*(1.5 - n)*x / n;
}
 
double sum1(double x, int n, double eps)
{
    if (n == 0)
        return obsch1(x, n);
    else
    {
        if (fabs(obsch1(x, n)) > eps)
            return sum1(x, n - 1, eps) + obsch1(x, n);
        else
            return sum1(x, n - 1, eps); 
    }
}
 
double obsch2(double x, int n)
{
    if (n == 0)
        return 1;
    else
        return obsch2(x, n - 1)*(0.5 - n)*x / n;
}
 
double sum2(double x, int n, double eps)
{
    if (n == 0)
        return obsch2(x, n);
    else
    {
        if (fabs(obsch2(x, n)) > eps)
            return sum2(x, n - 1, eps) + obsch2(x, n);
        else
            return sum2(x, n - 1, eps);
    }
}
 
    int main()
    {
        double x, y, eps;
        setlocale(LC_ALL, "Russian");
        cout << "Введите действительное число x (-1 < x < 1)";
        cin >> x;
        cout << "Введите вещественное число eps=";
        cin >> eps;
        y = 1.5*sum1(x, n, eps) - 0.5*sum2(x, n, eps);
        cout << "Значение функции y=" << y << endl;
        return 0;
    }
0
7437 / 5029 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.05.2019, 00:17 8
Цитата Сообщение от AlmariNuit Посмотреть сообщение
а с переменной n тогда что делать, везде она "необъявленный идентификатор".
правильно, Вы же не инициализировали её значением (там мусор), а передаёте в функцию. я подправил очевидные ошибки, в алгоритм не вникал, но сложилось впечатление, что Вы функции для работы с числом слагаемых n пытаетесь применить для вычислений с точностью eps.
0
0 / 0 / 0
Регистрация: 16.04.2019
Сообщений: 10
29.05.2019, 00:25  [ТС] 9
Yetty, ладно, спасибо Вам большое за помощь! Попробую дальше разобраться с n (вообще она не только означает количество членов ряда, но и участвует в вычислениях очередного элемента).
0
29.05.2019, 00:25
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.05.2019, 00:25
Помогаю со студенческими работами здесь

Вычисление значения функции двух переменных с использованием механизма исключений
Написать программу по исключению

Провести вычисление интеграла по формуле с использованием рекурсии
Провести вычисление интеграла вида f(n)=I{}_{n}= \int_{0}^{pi/2} cos{}^{n}(x)dx По формуле:...

Запрограммируйте с использованием рекурсии вычисление функции
Помогите пожалуйста решить задачу! Запрограммируйте с использованием рекурсии вычисление функции...

Нахождение значения функции с использованием рекурсии
Вот сама суть задачи: Найдите значение функции для любых целых неотрицательных аргументов. ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru