算法笔记练习 5.1 简单数学 问题 J: 多项式的值

算法笔记练习 题解合集

题目链接

题目

题目描述
实现一个多项式的类(a+bx+cx2+d*x3+…+),要求输入该多项式的系数和 x 的值后打印出这个多项式的值。

输入
输入第一行为样例数m,对于每个样例,第一行为多项式最高项次数n,接下来n+1个整数表示每项系数,最后一个整数x,n不超过10。

输出
输出 m 行,表示个多项式代入 x 后的值。

样例输入

1
2
1 2 3
2

样例输出

17

思路

秦九韶算法:
f ( x ) = a n x n + a n − 1 x n − 1 + ⋯ + a 1 x + a 0 = ( a n x n − 1 + a n − 1 x n − 2 + ⋯ + a 2 x + a 1 ) x + a 0 = ( ( a n x n − 2 + a n − 1 x n − 3 + ⋯ + a 3 x + a 2 ) x + a 1 ) x + a 0 \begin{aligned} f(x)&=a_nx^n+a_{n-1}x^{n-1}+\cdots+a_1x+a_0 \\&=(a_nx^{n-1}+a_{n-1}x^{n-2}+\cdots+a_2x+a_1)x+a_0 \\&=((a_nx^{n-2}+a_{n-1}x^{n-3}+\cdots+a_3x+a_2)x+a_1)x+a_0 \end{aligned} f(x)=anxn+an1xn1++a1x+a0=(anxn1+an1xn2++a2x+a1)x+a0=((anxn2+an1xn3++a3x+a2)x+a1)x+a0
所以从编程的角度而言,应该从次数最高的地方开始算。
以下运算符为 C 语言中的意义,假设 f ( x ) f(x) f(x) 的系数不全为 0:

  1. a n s = a n ans=a_n ans=an
  2. n   ! = 0 n\,!=0 n!=0,则 a n s   ∗  ⁣ =   x ans\,*\!=\,x ans=x a n s   +  ⁣ =   a n − 1 ans\,+\!=\,a_{n-1} ans+=an1 n = n − 1 n=n-1 n=n1
  3. 重复 2 直到 n = = 0 n==0 n==0.

代码

#include 
int main() {
	int m, n, x, i;
	while (scanf("%d", &m) != EOF) {
		while (m--) {
			scanf("%d", &n);
			int coe[n + 1]; 
			for (i = 0; i < n+1; ++i)
				scanf("%d", &coe[i]);
			scanf("%d", &x);
			
			int ans = coe[n];
			for (i = n - 1; i >= 0; --i){
				ans *= x;
				ans += coe[i]; 
			} 
			printf("%d\n",ans); 
		} 
	} 
	return 0;
} 

你可能感兴趣的:(算法笔记)