基础编程题6-2 PTA多项式求值

这个题目很有意思。

一开始我想的是最笨的办法,用了两个for循环,分别求出第n项的值,再加到sum上,最后return sum。这里就不贴代码了。

后来,我想到多项式可以变成乘积相加的形式,即:

a_{0}+a_{1}x^{^{1}}+a_{2}x^{^{2}}+......a_{n}x^{^{n}} = a_{0} + x(a_{1}+x(a_{2} + a_{3}x)... x (a_{n-1} + a_{n} x))))

代码如下:

double f( int n, double a[], double x ){
	int i = n-1;
	double sum;
	sum = a[n];
	while( i >= 0 ){
		sum = x * sum + a[i];
		--i;
	}
    return sum;
}

结果老是编译错误,让我十分懵逼。用了测试用例结果是对的。无奈,到网上找到一份可以编译通过的答案。(因为我没有返回return。。。)

double f( int n, double a[], double x )    
{    
    int i;    
    double X=1;    
    double sum=a[0]; 
    for(i=1;i<=n;i++)//之前两个for循环套用完全可以用一个for循环来代替    
    {     
         X=X*x;    
         sum=sum+X*a[i];     
    }    
    return sum;    
}  

现在还不知道我错在哪里了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值