c语言级数cosx
A. 如何用c语言设计计算cosx的近似值
1、首先在电脑中打开Dev-C++,接着在打开的操作主页面中,写好头函数#include <stdio.h>#include <math.h>。
B. c语言求COS怎么错了
你看看是不是你的C语言软件的配置有误.
软件一般不放在默认路径下,都会出现这种情况的.
你的串号我已经记下,采纳后我会帮你制作
C. C语言编程,cosx问题
请注意以下几点:1
,选择合适的数据结构,这将有助于和扩展。
2,算法完善,如果你正在写的困难,然后
尽量选择笨的办法,而不是费力编写复杂的代码
3,切成小代码尽可能的功能,一个功能一般不超过10行
4,变量命名约定不产生混淆
5,从最简单的,逐步的测试完成了测试部分的一部分,
不要等到一堆码,去测试,问题成片的结果,我不知道这个
6,精心挑选的测试情况下,不要随便进入,以防止隐藏的问题测试出
7,如果时间允许,尝试一个简单的评论
8,你可以添加一些测试代码,以确定程序状态
注意这几点,我认为,应该能够快速解决问题
D. 用c语言编写cosx函数
cosx函数
#include<stdio.h>
#include<math.h>
int main()
{
int n=0;
double x,sum=0;
printf("please enter x:");
scanf("%lf",&x);//
double cosx(double x,int n);
do
{
sum=sum+cosx(x,n);
n=n+1;
}
while(fabs(cosx(x,n))>1e-8);
printf("%9.8f\n",sum);
return 0;
}
double cosx(double x,int n)
{
double p,q;//
p=pow(x,2*n);
double fact(int n);//
q=fact(2*n);
if(n%2)
return(-p/q);
else
return(p/q);
}
double fact(int n)//
{
double ans=1; int i;
if(n<=1)
return 1;
for(i=1;i<=n; ++i)
ans*=i;
return ans;
}
cosx函数即反余弦函数
函数y=cosx(x∈[0,π])的反函数叫做反余弦函数,
记作y=arccosx(x∈[-1,1]).
E. 用C语言求cosX的值
x -- 用弧度值输入
精度 -- 1E-07
泰勒公式:
cos(x) = 1 - x^2/2! + x^4/4! - x^6/6! ...
程序:
#include<stdio.h>
#include<math.h>
void main(){
double x,term,sum,x2;
int i;
printf("input x in HuDu\n");
scanf("%lf",&x);
x2 = x * x;
sum = 1.0;
term = 1.0;
for (i=2;i<20;i=i+2){
term = term*x2/(double) (i * (i-1)) * (-1.0);
if (fabs(term) < 1.0E-07) break;
sum = sum + term;
}
printf("cos(x)=%lf\n",sum);
}
--------------
算例:
1.570796
cos(x)=0.000000
0.78539
cos(x)=0.707113
3.14159
cos(x)=-1.000000
F. C语言求cosx和它的近似值两个相互比较 谢谢
用Visualstudio 2019编写:
#define _STDC_WANT_LIB_EXT1_ 1
#include<stdio.h>
#include<math.h>
double term (int xn, double xrt, double rt);
main()
{
int a=0;
int at = 0;
double r = 0;
double rt = 0;
double rtc = 0;
int n = 0;
int i = 0;
double pi = 3.14159265;
printf("输入想要计算cos值的角度(注:不是弧度):");
scanf_s("%d", &a);
printf("输入想要在哪个角度展开泰勒级数:\n");
scanf_s("%d", &at);
printf("输入想展开泰勒级数的阶数:");
scanf_s("%d", &n);
r = a * pi / 180;
printf("系统计算%d度的cos值为:\n%f",a,cos(r));
rt = at * pi / 180;
for (i = 0; i <= n; i++)
{
rtc += term(i, rt, r);
}
printf("\n%d在%d处的cos%d阶泰勒展开值为:\n%f", a, at, n, rtc);
system("pause");
}
double term(int xn, double xrt, double xr)
{
double y = 0 ;
int x3 = 0;
int x4 = 0;
int divisor = 1;
double d = xr - xrt;
if (xn == 0)
d = 1;
for (x3 = 2; x3 <= xn; x3++)
{
d *= d;
}
for (x4 = 1; x4 <= xn; x4++)
{
divisor = divisor * x4;
}
switch (xn % 4)
{
case 0:
y = cos(xrt)*d/divisor;
break;
case 1:
y = -sin(xrt)*d/divisor;
break;
case 2:
y = -cos(xrt)*d/divisor;
break;
case 3:
y = sin(xrt)*d/divisor;
break;
}
return y;
}