• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

陈体胖

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

算法笔记练习 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)=anxn+an−1xn−1+⋯+a1x+a0=(anxn−1+an−1xn−2+⋯+a2x+a1)x+a0=((anxn−2+an−1xn−3+⋯+a3x+a2)x+a1)x+a0 \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)​=an​xn+an−1​xn−1+⋯+a1​x+a0​=(an​xn−1+an−1​xn−2+⋯+a2​x+a1​)x+a0​=((an​xn−2+an−1​xn−3+⋯+a3​x+a2​)x+a1​)x+a0​​
所以从编程的角度而言,应该从次数最高的地方开始算。
以下运算符为 C 语言中的意义,假设 f(x)f(x)f(x) 的系数不全为 0:

  1. 令 ans=anans=a_nans=an​;
  2. 若 n !=0n\,!=0n!=0,则 ans ∗ ⁣= xans\,*\!=\,xans∗=x,ans + ⁣= an−1ans\,+\!=\,a_{n-1}ans+=an−1​,n=n−1n=n-1n=n−1 ;
  3. 重复 2 直到 n==0n==0n==0.

代码

#include <stdio.h>
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;
} 

posted on 2020-03-30 12:51  陈体胖  阅读(136)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3