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

Вычислить значение функции y, развив функцию ln(x) в ряд Тейлора - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ С++ базы данных http://www.cyberforum.ru/cpp-beginners/thread103858.html
Я понимаю, что возможно следующие вопросы уже обсуждались на этом форуме, возможно и не раз, но по поиску ничего вразумительного (понятного мне) не нашел (как и в гугле). Поэтому прошу оставить негодование и помочь. Пишу проект (лабораторная) с БД (struct). При работе возникло несколько вопросов (прошу давать советы, которые будут работать под любым компилятором :) ): 1) В поле (столбец БД)...
C++ Ввести предложение, и вывести самое короткое слово? Ввести предложение, и вывести самое короткое слово??? Есть отдельная функция, которая удаляет подстроку со строки??? http://www.cyberforum.ru/cpp-beginners/thread103852.html
Динамическое выделение памяти new C++
Доброго времени. У меня в программе есть два двумерных динамических массива. Код компилируется, но возникает ошибка времени выполнения: "Инструкция по адресу "..." обратилась к памяти по адресу "...". Память не может быть "read"". если закоментировать выделение памяти под второй массив то программа работает без ошибок. Если попробовать выделить под второй массив совсем чуть-чуть памяти - один...
C++ Найти квадратный корень из суммы всех положительных элементов двухмерного массива
помогите очень-очень решить две задачки по массивам 1.Вычислить сумму элементов, больше, чем середнеарифметичне значение всех элементов. 2. Добыть квадратный корень из суммы всех положительных элементов двухмерного массива. Буду очень сильно благодарен!!!!!!
C++ Сложение и вычитание вещественных матриц http://www.cyberforum.ru/cpp-beginners/thread103778.html
ПОМОГИТЕ ПОЖАЛУЙСТА С ЗАДАЧКОЙ, СРОЧНО НУЖНО БЫЛО!!!!!!!!!, ВОТ И САМА ЗАДАЧКА.... Написать и протестировать функцию для сложения и вычитания вещественных матриц Одним из формальных параметров должен быть признак вида операции. зарание спасибо....
C++ Сортировка списков (Умножение полиномов) Задача: Имеются 2 полинома (А и В). Они задаются, как массив коэффициентов при иксах. Нужно создать третий полином (С = А * В) и представить его в виде списка, после чего отсортировать получившийся список. НО: в памяти нельзя хранить все элементы списка, то бишь в памяти - 3-10 значений, остальное - в неком временном файле. Собственно, вопрос: Как организовать это самое "НО"? подробнее

Показать сообщение отдельно
Lifastyle
0 / 0 / 0
Регистрация: 08.11.2009
Сообщений: 25
14.03.2010, 11:25     Вычислить значение функции y, развив функцию ln(x) в ряд Тейлора
Задача:
Вычислить значение функции y, развив функцию ln(x) в ряд Тейлора. Аргумент х изменяется от -1 до 3 с шагом 0.5. Определить погрешность.

Y=
ln(x)+ln(x/2) 0<x<=2
ln(x/2-1) 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
#include <stdio.h> //підключення бібліотек уведення-виведення
#include <conio.h>
#include <math.h> //підключення бібліотек математичних функцій
 
 
double logon(float x)
{ 
   float sum=x-1;     //сумма членов ряда
   int i=1;         //знаменатель элемента ряда
   float t=0.001;   //точность вычисления
   float member=x-1;  //текущий элемент ряда
   while (member>t) //пока текущий элемент превышает точность рассчетов
      { member=member*(-(x-1)/i); //текущий элемент за формулой Тейлора
         sum+=member;        // сумма
         i++;        }       //переход к новому елементу ряда
   return sum;    
 }
void main (void) 
{  
   float y,           //виражение за формулой Тейлора
         st,          //значение стандартной функции log
         x,           //аргумент функции
         xn, xk,      //начальное, конечное значение аргумента
         xs, err;    //шаг изенения аргумента и погрешность
printf("\n input xn, xk, xs (-1 3 0.5)\n");
scanf("%f%f%f", &xn, &xk, &xs);
puts("===================================================");
printf("     x             y          standart        error \n");
puts("===================================================");
 for ( x=xn;x<=xk;x+=xs)        //цикл перебора значений аргумента функции
  { if (0<=x<=2)        //проверка условий вибора рассчетной функции
      {  y=logon(x)–logon(x/2); //определение функции за формулой Тейлора
          st=log(exp(x))log(exp(x/2));   //определение функции за стандартною формулою
          err=st–y;     //расхождение между точним и приближенным значениями функции
     }
 else if (x>=2)
           { y=logon(x/2-1);
              st=log(exp(x/2-1));
              err=st–y;
    }
 printf ("  %f     %f     %f      %f \n", x, y, st, err);
   }
}
Помогите,пожалуйста,отладить код...убрать ошибки, неточности и т.д.
Только начинаюизучать язык...вся надежда на вас...
Буду благодарна лбой помощи!!!

Добавлено через 10 часов 22 минуты


Добавлено через 22 часа 5 минут
Вот еще немного поработала над кодом, но всё равно не компилируется...

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
#include <stdio.h> 
#include <conio.h>
#include <math.h> 
 
 
double logon(float x)
{ 
   float sum=x-1;     
   int i=1;         
   float t=0.001;   
   float member=x-1;  
   while (member>t) 
      { member=member*(x-1);
         sum+=member/i;          
         i++;        }       
   return sum;    
 }
void main (void) 
{  
   float y,           
         st,          
         x,           
         xn, xk,      
         xs, err;    
   int flag=0;     
printf("\n input xn, xk, xs (-1 3 0.5)\n");
scanf("%f%f%f", &xn, &xk, &xs);
puts("===================================================");
printf("     x             y          standart        error \n");
puts("===================================================");
 for ( x=xn;x<=xk;x+=xs)        
  { if (0<=x && x<=2)       
      {  y=logon(x)–logon(x/2); 
          st=log(x)log(x/2);;    
          err=st–y;     
    }
 else if (x>=2)
           { y=logon(x/2-1);
              st=log(x/2-1);
              err=st–y;
    }
else if (x<=0)  flag =1; 
    if ( flag==0)       
     printf ("  %f     %f     %f      %f \n", x, y, st, err);
     else    printf ("  %f     not define    \n", x ); 
   }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:02. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru