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

Найти интеграл - C++

Восстановить пароль Регистрация
Другие темы раздела
SFML Code Blocks и sfml http://www.cyberforum.ru/cpp-beginners/thread1309308.html
Не могу подружить данный компилятор с SFML при компоновке нет ошибок а при запуске программы пишет не найдена: sfml graphics 2.dll В чем загвоздка?
C++ Определить количество ненулевых значений Хелп профи. Всю голову уже сломал. Ввести с клавиатуры n целых чисел и определить количество ненулевых значений. Ввод чисел обсепечить с клавиатуры в цикле с помощью операторов for, while, do while на языке С. http://www.cyberforum.ru/cpp-beginners/thread1309304.html
Поменять местами минимальный среди четных элементов и первый элемент строки матрицы C++
Условие такое: Ввести матрицу A NxM , вывести ее. В каждой строке матрицы поменять местами минимальный среди четных элементов и первый элемент строки. Если нет четных элементов в строке, то оставить ее без изменения. #include "stdafx.h" #include <iostream> #include <math.h> using namespace std; int main() { int n, m, min, tmp; int l = 1;
Функция с переменным числом параметров заранее неизвестного типа C++
Здравствуйте, коллеги! Прошу помочь начинающему в С++. Есть функция с переменным числом параметров заранеее неизвестного типа. Внутри начинаю перебирать параметры по ссылке и на первом же неопределенном получаю проблему с типом float. Вот код: #include "stdafx.h" #include <iostream> #include <clocale> using namespace std;
C++ Запрос к mysql выполняется через раз http://www.cyberforum.ru/cpp-beginners/thread1309253.html
Всем привет. Вновь вынужден обратиться за помощью. Я написал класс, выполняющий запрос к mysql и записывающий результат в вектор. Но возник странный глюк - строка "res = stmt->executeQuery(query);" выполняется случайным образом. Иногда подряд несколько раз, иногда несколько раз не выполняется и результатов запроса я не вижу. Бывает что результат запроса содержит только часть строк из базы...
C++ Поменять местами в каждой строке матрицы минимальный и максимальный элементы, подскажите ошибки Помогите мне найти мои ошибки. В произвольной матрице поменять местами в каждой строке минимальный и максимальный элементы. Надо чтобы в этой программе были пункты меню (оператор switch-case): 1. Ввод матрицы с клавиатуры 2. Случайный ввод матрицы 3. Вывод матрицы на экран подробнее

Показать сообщение отдельно
Roozevelt
0 / 0 / 0
Регистрация: 22.10.2013
Сообщений: 75
25.11.2014, 22:31  [ТС]     Найти интеграл
Помогите пожалуйста разобраться почему не работает прога
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
/*Вычисление интеграла exp(ax)*(1+x^2)*(sinx/x+2) Методом Симпсона */
 
#include <iostream>
#include <math.h> //Подключаем библиотеки
#include <iomanip>
using namespace std;
double e = 2.718281828459045; //Объявляем константы
double f(double x)
{
    for (int a = 0,019; a <= 5; a++)
    {
 
        double fn = fn = (pow(e, a * x)) * (1 + (pow(x, 2))) * (sin(x)/x + 2 ); //Функция f(x)
        return fn;
    }
}
double Simpson(double a, double b, double e) //Реализация метода Симпсона. В качестве параметров функция принимает
//Пределы интегрирования и точность вычисления
{
    int n = 6; //Первоначально разбиваем промежуток a,b на n частец
    double h = 0.001; //Вычисляем шаг
    double x2, S, I2, I1, w; //Переменные необходимые для расчетов
    int k = 1; //Задаём начальные
    I1 = 0; //Параметры 
    double s0 = f(a) + f(b); //Находим чему равна сумм значений функций на концах отрезка
    do
    {
        double x1 = a + 0.004; //Делаем шаг
        S = 0;
        for (int i = 1; i<n; i++)
        {
            double s = (k + 3)*f(x1);
            k = -k;
            x2 = x1 + 0.001; //Этим циклом найдем сумму значений функции в узлах интегрирования
            x1 = x2;
            S += s;
 
        }
 
        x1 = 0;
 
        n = 2 * n; //Удваиваем количество разбиений
        cout << "kol razbien: " << n << endl;
        double h1 = (b - a) / n; //Вычисляем новый шаг
        I2 = 0.001 / 3.*(s0 + S); //Находим значение интеграла на малом участке
        w = fabs(I2 - I1); //Вычисляем модуль разности нового значения интеграла и того что было
        I1 = I2;
        h = h1;
 
    } while (w>e); //цикл do работает пока не будет достигнута нужная точность
    return I2;
}
 
void main()
{
    double a, b, e; //Пределы интегрирования и точность
    a = 0; b = 1; e = 0.0001;
    cout << " integr: " << setprecision(8) << Simpson(a, b, e)<<endl; //Вызываем функцию
}
 
Текущее время: 08:33. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru