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

Метод Пирсона - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ язык С++ http://www.cyberforum.ru/cpp-beginners/thread959771.html
Помогите, решить задачу на языке С++: Надано список цілих чисел. Перевірити чи підкоряються значення у списку арифметичній прогресії Перенесено из раздела Pascal. Официальными языками форума являются русский и английский.
C++ Работа с перегрузкой сложения Ребята суть задачки в фото , помогите пожалуйста . http://www.cyberforum.ru/cpp-beginners/thread959763.html
возведение в степень C++
всем доброго времени суток, задача такая: возвести х в 10 степень, но вывод осуществить при помощи printf int main() { double x,y; printf("Input x:"); scanf("%i",&x); y=pow(x,10.0); printf("%i",y); } но при выполнение он выводит "0", в чем ошибка??
Задача (Функції) C++
Написати функцію обчислення поточної вартості автомобіля, який використовується п’ять років, якщо відомі його початкова вартість та величина річного проценту здешевлення автомобіля. Застосувати цю функцію у головній програмі для чотирьох різних значень початкової вартості та проценту здешевлення автомобіля. Написать функцию вычисления текущей стоимости автомобиля, который используется пять лет,...
C++ Параметры шаблонов функции по умолчанию http://www.cyberforum.ru/cpp-beginners/thread959749.html
есть функция template<class T> T sum(valarray<T> x, size_t left = 0, size_t right = 0){ T result = 0; if(right == 0) right = x.size() - 1; for(size_t i = left; i<=right; i++){ result += x; } return result;
C++ Почему кричит компилер? #include <stdio.h> #include <windows.h> #include <math.h> #include <iostream> void main () { const float pi = 3.14159; setlocale(0,""); float ax,ay,az,bx,by,bz; float angle; float scal; подробнее

Показать сообщение отдельно
Kostas94
Сообщений: n/a
22.09.2013, 16:51     Метод Пирсона
Ребят, завтра сдавать работу по методу Симпсона. Уже который день мучаюсь, но не могу добиться требуемой точности, а завтра сдавать, помоги пожалуйста.
Информацию брал отсюда:
http://www.cleverstudents.ru/definit...parabolas.html
Делал по примерам.
Необходимо с помощью этого метода найти интеграл от 0 до 10 от cos(x^2). Вот код:

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
#include "stdafx.h"
#include <Math.h>
#include <iostream>
using namespace std;
    
double pr (double y){
        double perem=8*y* ( 20*(pow(y,2)) * cos (pow (y,2)) + (15-4*pow(y,4)) * sin(pow(y,2)) );//производная 5 степени для нахождения максимума
        return perem;
    }
int _tmain(int argc, _TCHAR* argv[]){
 
 
    double b=10;//границы
    double a=0;
    int par1=-9;
    double par2=10;
    double eps=pow (par2, par1); // точность по заданию
    double max=0;
    for (double y=0; y<=10;y=y+0.000001){ //поиск максимума через 5 производную
            if (pr (y) > max){
                max=pr (y);
            }
        }
 
    printf ("max %f\n", max);
    double step=0.25;
    double argument=(max*pow((b-a),5))/(eps*180); 
    
    double n=pow (argument,step); // формула нахождения количества отрезков разбиения
    double h=(b-a)/n;//нахождения шага
    printf ("h %f\n", h);
    double z=0;//то что нужно посчитать
    long double x=0;//итоговый результат
    n=36300;//поскольку хз как округлить нормально задал +1 количество шагов, при прохождение программы выдаёт 36299.123.....
 
    for (int i=0; i<=n; i++){                   //сам алгоритм подсчёта
        if ((i==0) || (i==n)){
        x=x+cos (z*z);
        z=z+h;
        } else 
            if (i%2==0){
                x=x+2*(cos (z*z));
                z=z+h;
            } 
            else{
            x=x+4*(cos(z*z));
            z=z+h;
            }
    }
 
 
    double ans=x*(h/3);//конечный результат
    
    printf ("kol-vo otrezkov %.9f\n", n);
    printf ("ans %.9f\n", ans);
    getchar();
    return 0;
}
Понятия не имею что неверно, выдаёт значение 0.601139903, а должен 0.601125185.
Второе (верное) значение получил в Scilabе, и считал онлайн, тоже самое получилось. Помогите пожалуйста.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 07:09. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru