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

Разбить функцию main на две - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ создать матрицу которая будет заменять элементы четных строк на цифры от 0 до 9 http://www.cyberforum.ru/cpp-beginners/thread1054348.html
создать матрицу которая будет заменять элементы четных строк на цифры от 0 до 9.
C++ Работает в онлайн компиляторах, но не работает у меня Проверяю данные, но на компьютере не работает, в чем роблема? #include <string.h> #include <stdlib.h> #include <stdio.h> #define MAX(A,B) (((A)>(B))? (A) : (B)) char * lcs(const char *a,const char * b) { int lena = strlen(a)+1; int lenb = strlen(b)+1; http://www.cyberforum.ru/cpp-beginners/thread1054337.html
C++ обработка литерных величин с++
обработка литерных величин по с++ Подсчитайте количество шипящих букв в слове. Удалите из слова буквы, стоящие на четных местах. Удвойте гласные в слове. Заранее благодарен :)
C++ Найти производную функции
найти производную функции f(x)=sinx(cosx-x^3) по определению (delta=0.1)в точках из интервала [0,5) с шагом 0,5. заранее благодарен:)
C++ обработка литерных величин по с++ http://www.cyberforum.ru/cpp-beginners/thread1054332.html
Помогите пожалуйста.. обработка литерных величин по с++ Подсчитайте количество шипящих букв в слове. Удалите из слова буквы, стоящие на четных местах. Удвойте гласные в слове. Зарание благодарен :)
C++ программирование обработка литерных величин по с++ Помогите пожалуйста.. обработка литерных величин по с++ Подсчитайте количество шипящих букв в слове. Удалите из слова буквы, стоящие на четных местах. Удвойте гласные в слове. Зарание благодарен:) подробнее

Показать сообщение отдельно
aimbat
0 / 0 / 0
Регистрация: 07.10.2013
Сообщений: 81

Разбить функцию main на две - C++

24.12.2013, 03:22. Просмотров 199. Ответов 0
Метки (Все метки)

Друзья, нужно разбить функцию 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
#include <iostream>
#include <cmath>
#include <iomanip>
 
using namespace std;
// функция считает факториал целого числа
long double Fact( long n );
// функция считает приближенно cos^2( x ) при помощи ряда Тейлора
// - значение x
// - точность вычислений
// - флаг, который определяет рекурсивно ли вызвана функция или впервые для данного x
long double Calc( long double x, const long double e, bool flagNew = true);
 
int main() {
 
     double xBegin, xEnd; // начальное и конечное значения x
     unsigned count; // количество вычисляемых значений на отрезке от начального до конечного значения x [ xBegin, xEnd ]
     double epsilon; // точность вычисления
 
     // запрашиваем у пользователя исходные данные
     cout << "Введите начальное и конечное значения x ( в радианах )" << endl;
     cin >> xBegin >> xEnd;
 
     cout << "Введите количество вычисляемых значений" << endl;
     cin >> count;
 
     cout << "Введите точность вычислений" << endl;
     cin >> epsilon;
 
     const double xDelta = ( xEnd - xBegin ) / ( count - 1 ); // находим шаг для вычислений
     cout << "Шаг для вычислений " << xDelta << "( радиан )" << endl;
 
     // в цикле вызываем функцию для рассчета очередного значения начиная с xBegin и заканчивая xEnd - xDelta элементом
     for ( unsigned i = 0; i < count - 1; ++i )
     cout << "X" << i + 1 << " = " << setprecision( 3 ) << Calc( xBegin + xDelta * i, epsilon ) << endl;
 
     // значение функции Calc( xEnd ) я решил вычислить отдельно, так как работаю с плавающей точкой
     // и при суммировании в цикле может быть неточность при вычислении граничного значения xEnd.
     cout << "X" << count << " = " << setprecision( 3 ) << fixed << Calc( xEnd, epsilon ) << endl;
 
 
    return 0;
}
 
long double Calc( long double x, const long double e, bool flagNew ) {
    static long double p; // степень
    static int koef; // для знака + или -
    // если функцию вызвали в первый раз - т.е. нерекурсивно
    if ( flagNew ){ // то устанавливаем начальные значения степени и коэффициента
        koef = 1;
        p = 2.0;
    }
    // для того чтобы в следующем операторе в вычислениях с правой стороны от знака "="
    // поменять знак очереднго элемент ряда на противоположенный знаку, который был в пердыдущем вычислении
    koef *= -1;
 
    // вычисляем очередной элемент ряда
    long double res = ( pow( x, p ) * pow( 2.0L, p - 1 ) / Fact( p ) ) * koef;
 
    // проверка на окончание рекурсии
    if ( fabs( res ) <= e ) // если очередной элемент ряда по модулю менее или равен epsilon
        return 1 + res; // то возвращаем значение и прерываем рекурсию
    else { // а если не
        p += 2.0; // то увеличиваем степень
        // прибавляем к очередному элементу ряда следующий элемент ряда, который будет вычислен рекурсивно
        return res + Calc( x, e, false );
    }
 
}
 
long double Fact( long n ) {
    return n > 0 ? n * Fact( n - 1 ) : 1;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru