Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 2 / 1
Регистрация: 13.11.2018
Сообщений: 83

исправление ошибки

14.12.2018, 20:26. Показов 1498. Ответов 8

Студворк — интернет-сервис помощи студентам
Народ как исправить эту ошибку
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
#include "pch.h"
#include <iostream> 
#include <cmath>
 
using namespace std;
 
void f(float x0[])
{
    float x = x0[0];
    float x1 ;
     x1= tan(7 * x) + pow(x, 2) * sin(x) + 1;
}
float df(float x)
{
    float dxx = 0.0001;
    float *dx = &dxx;
    float *x1 = &x;
    return (f(x + dx) - f(x1)) / dx; // она тут 
}
float df2(float x)
{
    float dx = 0.0001;
    return (df(x + dx) - df(x)) / (dx);
}
float Root(float b, float eps)
{
    float x = b;
    float x0 = x;
    while (abs(df(x)) > eps)
    {
        x = x0 - df(x0) / df2(x0);
        x0 = x;
    }
    return x;
}
 
/*float Root1(float b, float eps)
{
 float *x0 = &b;
 float *x[] = { x0 };
 while (abs(f(x[0])) > eps)
 {
  *x[0] = *x0 - f(x0) / df(x0);
  x0 = *x;
 }
 return *x[0];
}*/
int main()
{
    setlocale(LC_ALL, "Rus");
    float a, b, eps;
    cout << "Введите границы отрезка [a;b] для нахождения максимума функции ";
    cout << "\nВведите левую границу отрезка a = "; cin >> a;
    cout << "Введите правую границу отрезка b = "; cin >> b;
    cout << "Введите значение погрешности E = "; cin >> eps;
    cout << "\n";
    float *a1 = &a;
    float *b1 = &b;
 
 
    if (a >= b)
    {
        cout << "Неверно указан интервал поиска" << endl;
        system("pause");
        return 0;
    }
    if (eps <= 0)
    {
        cout << "Значение погрешности должно быть положительным" << endl;
        system("pause");
        return 0;
    }
 
    /*if (Root1(b, eps) > b || Root1(b, eps) < a) {
     cout << "На этом интервале корней нету!" << endl;
    }
    else
    {
     cout << "Корень функции: " << Root1(b, eps) << endl;
    }*/
 
     if (Root(b, eps) > b || Root(b, eps) < a)
 {
  f(a1);
  f(b1);
  if (*a1 > *b1) {
   cout << "Максимум функции1: " << *a1 << endl;
  }
  else cout << "Максимум функции2: " << *b1 << endl;
 }
 else 
 {
  f(a1);
  f(b1);
  if ((*a1 > Root(b, eps) && (*a1 > *b1))) 
  {
   cout << "Максимум функции3: " << *a1 << endl;
  }
  else if (*b1 > Root(b, eps) && (*b1 > *a1)) 
  {
   cout << "Максимум функции4: " << *b1 << endl;
  }
  else if ((Root(b, eps) > *a1 && (Root(b, eps) > *b1))) {
   cout << "Максимум функции5: " << Root(b, eps) << endl;
  }
 }
    system("pause");
    return 0;
}
Миниатюры
исправление ошибки  
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.12.2018, 20:26
Ответы с готовыми решениями:

Исправление ошибки
Здравствуйте. Не могу понять, в чем заключается ошибка кода и как ее решить. Помогите, пожалуйста. float d = 4.4; //значение первой...

исправление ошибки
задание:напишите программу, которая считывает строку символов, выбирает числа из этой строки и записывает их в стек. вывести содержимое...

Исправление ошибки
Как сделать в else чтобы число n генерировалось заново,если числа n и m не простые? #include &lt;iostream&gt; #include...

8
249 / 219 / 63
Регистрация: 30.07.2013
Сообщений: 465
14.12.2018, 20:41
C++
1
2
3
4
5
6
float df(float x)
{
    float dx = 0.0001;
    float x1 = x + dx;
    return (f(&x1) - f(&x)) / dx;
}
1
0 / 2 / 1
Регистрация: 13.11.2018
Сообщений: 83
14.12.2018, 20:51  [ТС]
та же ошибка только на букве f
0
249 / 219 / 63
Регистрация: 30.07.2013
Сообщений: 465
14.12.2018, 21:00
C++
1
2
3
4
5
6
7
8
9
10
11
12
float f(float x0[])
{
    float x = x0[0];
    return tan(7 * x) + pow(x, 2) * sin(x) + 1;
}
 
float df(float x)
{
    float dx = 0.0001f;
    float x1 = x + dx;
    return (f(&x1) - f(&x)) / dx;
}
1
0 / 2 / 1
Регистрация: 13.11.2018
Сообщений: 83
14.12.2018, 21:03  [ТС]
хмм в том то и проблема что надо что-бы функция была void
0
249 / 219 / 63
Регистрация: 30.07.2013
Сообщений: 465
14.12.2018, 21:08
void по определению ничего не возвращает, так что либо надо переформулировать вопрос/задачу, либо все-таки не void
1
0 / 2 / 1
Регистрация: 13.11.2018
Сообщений: 83
14.12.2018, 21:11  [ТС]
смотри надо сделать так чтобы функция f была void и в параметрах был массив .я знаю что она не возвращает
0
249 / 219 / 63
Регистрация: 30.07.2013
Сообщений: 465
14.12.2018, 21:20
Лучший ответ Сообщение было отмечено Bogdan17 как решение

Решение

какими-то вы там извращениями занимаетесь
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void f(float x[2])
{
    x[1] = tan(7 * x[0]) + pow(x[0], 2) * sin(x[0]) + 1;
}
 
float df(float x)
{
    float dx = 0.0001f;
    float x0[2] = { x, 0.0f };
    float x1[2] = { x + dx, 0.0f };
 
    f(x0);
    f(x1);
 
    return (x1[1] - x0[1]) / dx;
}
1
0 / 2 / 1
Регистрация: 13.11.2018
Сообщений: 83
14.12.2018, 22:03  [ТС]
нет не раб

Добавлено через 10 минут
спс что помог там немного не так надо было
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
#include "pch.h"
#include <iostream> 
#include <cmath>
 
using namespace std;
 
void f(float x0[])
{
    float x = x0[0];
    x0[0] = tan(7 * x) + pow(x, 2) * sin(x) + 1;
}
float df(float x)
{
    float ddx = 0.0001;
    float *dx = &ddx;
    float x0[1] = { x };
    float *x1 = &x0[0];
    float *temp = new float;
    *temp = *x1 + *dx;
    f(temp);
    f(x1);
    return (*temp - *x1) / *dx;
}
float df2(float x)
{
    float dx = 0.0001;
    return (df(x + dx) - df(x)) / (dx);
}
float Root(float b, float eps)
{
    float x = b;
    float x0 = x;
    while (abs(df(x)) > eps)
    {
        x = x0 - df(x0) / df2(x0);
        x0 = x;
    }
    return x;
}
 
/*float Root1(float b, float eps)
{
 float *x0 = &b;
 float *x[] = { x0 };
 while (abs(f(x[0])) > eps)
 {
  *x[0] = *x0 - f(x0) / df(x0);
  x0 = *x;
 }
 return *x[0];
}*/
int main()
{
    setlocale(LC_ALL, "Rus");
    float a, b, eps;
    cout << "Введите границы отрезка [a;b] для нахождения максимума функции ";
    cout << "\nВведите левую границу отрезка a = "; cin >> a;
    cout << "Введите правую границу отрезка b = "; cin >> b;
    cout << "Введите значение погрешности E = "; cin >> eps;
    cout << "\n";
    float *a1 = &a;
    float *b1 = &b;
 
 
    if (a >= b)
    {
        cout << "Неверно указан интервал поиска" << endl;
        system("pause");
        return 0;
    }
    if (eps <= 0)
    {
        cout << "Значение погрешности должно быть положительным" << endl;
        system("pause");
        return 0;
    }
 
    /*if (Root1(b, eps) > b || Root1(b, eps) < a) {
     cout << "На этом интервале корней нету!" << endl;
    }
    else
    {
     cout << "Корень функции: " << Root1(b, eps) << endl;
    }*/
 
    if (Root(b, eps) > b || Root(b, eps) < a)
    {
        f(a1);
        f(b1);
        if (*a1 > *b1) {
            cout << "Максимум функции1: " << *a1 << endl;
        }
        else cout << "Максимум функции2: " << *b1 << endl;
    }
    else
    {
        f(a1);
        f(b1);
        if ((*a1 > Root(b, eps) && (*a1 > *b1)))
        {
            cout << "Максимум функции3: " << *a1 << endl;
        }
        else if (*b1 > Root(b, eps) && (*b1 > *a1))
        {
            cout << "Максимум функции4: " << *b1 << endl;
        }
        else if ((Root(b, eps) > *a1 && (Root(b, eps) > *b1))) {
            cout << "Максимум функции5: " << Root(b, eps) << endl;
        }
    }
    system("pause");
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.12.2018, 22:03
Помогаю со студенческими работами здесь

Исправление ошибки
Добрый день, ув. форумчане! Помогите, пожалуйста, исправить ошибку. Не пойму в чём проблема. std::vector &lt;unsigned char&gt; converter...

Исправление ошибки в коде
Всем доброе утро!!!Вот тут задачка запускается , вроде все по примеру делал ,все равно не хочет работать((. Вот сама задачка: # include...

Исправление ошибки в программе
Задача напечатать таблицу значений в виде |N | x | S(x) | F(x) | Х изменяется в диапазоне от a до b с шагом h. Вычисление суммы вести...

Исправление ошибки. Строки С++
Помогите, пожалуйста, с решением следующей задачи: Пусть имеется словарь, состоящий не менее чем из 20 слов. С клавиатуры вводятся слова,...

Исправление ошибки в работе со строками
Каждый раз в моём коде со строками выдает эту ошибку. Иногда, если проигнорировать её, всё запустится, а иногда - нет. В чём проблема? ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru