По разделам

 

Решение задачи Proc 41


Описать функцию Sin1(x, ε) вещественного типа (параметры x, ε —
вещественные, ε > 0), находящую приближенное значение функции sin(x):
sin(x) = x − x
3
/(3!) + x
5
/(5!) − . . . + (−1)n
·x
2·n+1/((2·n+1)!) + . . . .
В сумме учитывать все слагаемые, модуль которых больше ε. С помощью Sin1 найти приближенное значение синуса для данного x при шести
данных ε.

Код (C/C++)

#include <stdio.h>

float sin1(float x, float e){
    float xi=x,ni=1,rez=0,temprez=x;
    int i=1,znak=1;
 
    while(temprez > e){
 
        temprez=xi/ni;
        rez+=znak*temprez;
        znak*=-1;
        xi*=x;
        xi*=x;
        ++i;
        ni*=i;
        ++i;
        ni*=i;
        printf("%f\n%f\n",xi,ni);
    }
    return rez;
}
 
int main(void)
{
    float x,e;
    printf("X:");
    scanf("%f", &x);
    int i;
    for(i=1;i<=6;++i){
        printf("E: ");
        scanf("%f", &e);
        printf("Sin: %f\n",sin1(x,e));
    }
    return 0;
}

Код (Python)

import random
import math

def Sin1(x,eps):
    if eps <= 0:
        print("Epsilon should be greater than 0")
    y = x
    f = x
    i = 3
    while abs(y) > eps:
        y *= (-1) * x * x / ((i-1)*i)
        i += 2
        f += y
    return f

eps = 0.01
for i in range(0, 6):
    #x = -0.5
    #x = 2
    x = math.pi / 4
    print("eps = ", eps, "; sin(",x,") = ",Sin1(x,eps),";",math.sin(x))
    eps /= 10
									

Код (Pascal)

program Proc41;
 
Function Sin1(x,e:Real):Real;
var
 Znak,i:integer;
 xi,ni:Real;
 TempRez,Rez:Real;
begin
 xi:=1;
 i:=0;
 ni:=1;
 Znak:=-1;
 Rez:=0;
 TempRez:=x;
 
 While (abs(TempRez) > e) do
  begin
   if odd(i) then
    begin
     Znak:=Znak*(-1);
     Rez:=Rez+Znak*TempRez;
    end;
   inc(i);
   xi:=xi*x;
   ni:=ni*i;
  if odd(i) then
   begin
    TempRez:=xi/ni;
   end;
  end;
 Sin1:=Rez;
end;
 
 
var
  X,E:real;
  i: integer;
 
begin
   Write('X :');
   Readln(X);
   for i:=1 to 6 do
    begin
     Write('E :');
     Readln(E);
     Writeln(Sin1(X,E));
    end;
end.
									




Proc. Абрамян
Proc 1 Просмотров: 6511
Proc 2 Просмотров: 5031
Proc 3 Просмотров: 5115
Proc 4 Просмотров: 4302
Proc 5 Просмотров: 3361
Proc 6 Просмотров: 4606
Proc 7 Просмотров: 3890
Proc 8 Просмотров: 2984
Proc 9 Просмотров: 3123
Proc 10 Просмотров: 2880
Proc 11 Просмотров: 2983
Proc 12 Просмотров: 2180
Proc 13 Просмотров: 2421
Proc 14 Просмотров: 2654
Proc 15 Просмотров: 1864
Proc 16 Просмотров: 2839
Proc 17 Просмотров: 2484
Proc 18 Просмотров: 2405
Proc 19 Просмотров: 2323
Proc 20 Просмотров: 3169
Proc 21 Просмотров: 3296
Proc 22 Просмотров: 2400
Proc 23 Просмотров: 2397
Proc 24 Просмотров: 1658
Proc 25 Просмотров: 2030
Proc 26 Просмотров: 1805
Proc 27 Просмотров: 2005
Proc 28 Просмотров: 1735
Proc 29 Просмотров: 1914
Proc 30 Просмотров: 2444
Proc 31 Просмотров: 1668
Proc 32 Просмотров: 1220
Proc 33 Просмотров: 1248
Proc 34 Просмотров: 1670
Proc 35 Просмотров: 1153
Proc 36 Просмотров: 1612
Proc 37 Просмотров: 1473
Proc 38 Просмотров: 1193
Proc 39 Просмотров: 1097
Proc 40 Просмотров: 1830
Proc 41 Просмотров: 1896
Proc 42 Просмотров: 1148
Proc 43 Просмотров: 1115
Proc 44 Просмотров: 997
Proc 45 Просмотров: 1125
Proc 46 Просмотров: 996
Proc 47 Просмотров: 1058
Proc 48 Просмотров: 810
Proc 49 Просмотров: 1045
Proc 50 Просмотров: 2075
Proc 51 Просмотров: 1681
Proc 52 Просмотров: 1686
Proc 53 Просмотров: 1171
Proc 54 Просмотров: 1258
Proc 55 Просмотров: 1144
Proc 56 Просмотров: 1738
Proc 57 Просмотров: 1488
Proc 58 Просмотров: 1171
Proc 59 Просмотров: 1082
Proc 60 Просмотров: 1364

Комментарии

Чтобы написать комментарии вам нужно войти в систему или зарегистрироваться



Заявка на расчет