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

С помощью цикла do while организовать вычитание, пока не будет достигнута заданная точность.

31.03.2015, 19:35. Показов 2114. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
требуется реализовать цикл,в котором в конце будет проверяться условие что b3-b по модулю меньше допустим числа 0.0001. цикл один раз проходит,в итоге получается разность b3-b равна 0.00179076,что больше 0.0001. проблема в том что повторно цикл не повторяется,в чём моя ошибка?
C++
1
2
3
4
5
6
7
8
9
10
                do
        {
            m1 = m2;
            m2 = m3;
            b1 = b2;
            b2 = b3;
            m3 = m2 + (((m2 - m1)*(b - b2)) / (1.0*(b2 - b1)));
            z0 = m3;
            b3 = shoot(x0, y0, z0, xn, h, p = 0);
        } while (fabs(b3 - b) < eps);
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.03.2015, 19:35
Ответы с готовыми решениями:

Вычислить значение суммы пока не будет достигнута точность 10^-5
вычислить значение суммы пока не будет достигнута точность 10^-5 .для вычисления использовать только арифметические действия. ...

Найти все корни следующего уравнения с точностью 10^-7 и проверить, достигнута ли заданная точность:
tgx=lgx+pi на отрезке Помогите пожалуйста У меня получается так: options=optimset('TolX',10^(-7)); &gt;&gt; &gt;&gt;...

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

2
 Аватар для Beretnash
6 / 6 / 5
Регистрация: 14.07.2014
Сообщений: 24
31.03.2015, 19:43
Полный код можно?
0
0 / 0 / 1
Регистрация: 11.03.2014
Сообщений: 86
31.03.2015, 19:47  [ТС]
Beretnash,
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
114
115
116
117
#include "stdafx.h"
#include <iostream>
#include<stdio.h>
#include<math.h>
#include <iomanip>
#include<stdlib.h>
using namespace std;
float f1(float x,float y,float z)
{
    return(z);
}
float f2(float x,float y,float z)
{
    return(exp(x)+sin(y));
}
float shoot(float x0,float y0,float z0,float xn,float h,int p)
{
    float x,y,z,k1,k2,k3,k4,l1,l2,l3,l4,k,l,x1,y1,z1;
    x=x0;
    y=y0;
    z=z0;
    do
    {
        k1=h*f1(x,y,z);
        l1=h*f2(x,y,z);
        k2=h*f1(x+h/2.0,y+k1/2.0,z+l1/2.0);
        l2=h*f2(x+h/2.0,y+k1/2.0,z+l1/2.0);
        k3=h*f1(x+h/2.0,y+k2/2.0,z+l2/2.0);
        l3=h*f2(x+h/2.0,y+k2/2.0,z+l2/2.0);
        k4=h*f1(x+h,y+k3,z+l3);
        l4=h*f2(x+h,y+k3,z+l3);
        l=1/6.0*(l1+2*l2+2*l3+l4);
        k=1/6.0*(k1+2*k2+2*k3+k4);
        y1=y+k;
        x1=x+h;
        z1=z+l;
        x=x1;
        y=y1;
        z=z1;
        if(p==1)
        {
            
            cout<<left<<setw(10)<<fixed<<x<<right<<setw(10)<<fixed<<y<<endl;
        }
    }while(x<xn);
    return(y);
}
int main()
{
    setlocale(LC_CTYPE,"Russian");
    float x0, y0, h, xn, yn, z0, m1, m2, m3, b, b1, b2, b3, e, eps = 0.0001;
    int p=0;
    cout<<"Введите x0,y0,xn,yn,h:"<<endl;//начальное значение х ( 0 ), начальное значение Y ( 0 ), конечное значение х ( п ), окончательное значение Y ( п ) и Значение приращения (H).
    cin>>x0>>y0>>xn>>yn>>h;
    cout<<"Введите первое исходное значение M1:";
    cin>>m1;
    b=yn;
    z0=m1;
    b1=shoot(x0,y0,z0,xn,h,p=1);
    cout<<endl<<"B1 равно "<<b1<<endl;
    if(fabs(b1-b)<eps)
    {
        cout<<"Величина x и соответствующая z равны";
        e=shoot(x0,y0,z0,xn,h,p=1);
        return(0);
    }
    else
    {
    cout<<"Введите второе исходное значение  M2:";
    cin>>m2;
    z0=m2;
    b2=shoot(x0,y0,z0,xn,h,p=1);
    cout<<endl<<"B2 равно "<<b2<<endl;
    }
    if(fabs(b2-b)<eps)
    {
         cout<<"Величина x и соответствующая z равны";
         e= shoot(x0,y0,z0,xn,h,p=1);
         return(0);
    }
    else
    {   
        cout<<"M1= "<< m1<<endl;
        cout<<"M2= "<< m2<<endl;
        m3=m2+(((m2-m1)*(b-b2))/(1.0*(b2-b1)));
        if(b1-b2==0)
        exit(0);
 
        cout<<endl<<"Точное значение M="<<m3<<endl;
        z0=m3;
        b3=shoot(x0,y0,z0,xn,h,p=0);
    }
    if(fabs(b3-b)<eps)
    {
        cout<<endl<<"Существует решение:"<<endl;
        e=shoot(x0,y0,z0,xn,h,p=1);
        cout<<endl;
        system ("pause");
    }
    
 
        do
        {
            m1 = m2;
            m2 = m3;
            b1 = b2;
            b2 = b3;
            m3 = m2 + (((m2 - m1)*(b - b2)) / (1.0*(b2 - b1)));
            z0 = m3;
            b3 = shoot(x0, y0, z0, xn, h, p = 0);
        } while (fabs(b3 - b) < eps);
    
       z0=m3;
       e=shoot(x0,y0,z0,xn,h,p=1);
       cout<<endl;
        system ("pause");
     }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.03.2015, 19:47
Помогаю со студенческими работами здесь

Вычислить бесконечную сумму с заданной точностью ε> 0. Считать, что заданная точность достигнута, если абсолютная величина очередного слагаемого не пр
Вычислить бесконечную сумму с заданной точностью ε&gt; 0. Считать, что заданная точность достигнута, если абсолютная величина очередного...

Определить количество слагаемых суммы при которой будет достигнута точность
Определить кол-во слагаемых суммы при которой будет достигнута точность 1*{10}^{-5} при x=2. ...

Как задать подстановку значений в уравнение до тех пор, пока не выполнится заданная точность
Здравствуйте. Такой вопрос. Как задать маткаду подстановку значений в уравнение до тех пор, пока не выполнится заданная точность? Может,...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru