模板题。

拉格朗日插值的精髓在于这个公式

$$f(x) = \sum_{i = 1}^{n}y_i\prod _{j \neq i}\frac{x - x_i}{x_j - x_i}$$

其中$(x_i, y_i)$是给定的$n$个点值。

代入任何一个给定的点值坐标$x_k$,都会发现这个式子等于$y_k$成立,因为对于任何$i \neq k$,后面的系数都至少有一项为$0$,而当$i == k$的时候,后面那一项一定为$1$,这样子就可以保证代进去的点值一定被满足。

因为题目中要求直接代入$x$求值,所以在算这个式子的时候直接把$x$代进去计算就可以了,时间复杂度$O(n^2)$,要不然求系数的过程相当于高斯消元,时间复杂度$O(n^3)$。

Code:

#include <cstdio>
#include <cstring>
using namespace std;
typedef long long ll; const int N = ;
const ll P = 998244353LL; int n;
ll k, xi[N], yi[N]; template <typename T>
inline void read(T &X) {
X = ; char ch = ; T op = ;
for (; ch > '' || ch < ''; ch = getchar())
if (ch == '-') op = -;
for (; ch >= '' && ch <= ''; ch = getchar())
X = (X << ) + (X << ) + ch - ;
X *= op;
} inline ll fpow(ll x, ll y) {
ll res = 1LL;
for (; y > ; y >>= ) {
if (y & ) res = res * x % P;
x = x * x % P;
}
return res;
} int main() {
read(n), read(k);
for (int i = ; i <= n; i++)
read(xi[i]), read(yi[i]); ll ans = 0LL;
for (int i = ; i <= n; i++) {
ll mul1 = 1LL, mul2 = 1LL;
for (int j = ; j <= n; j++) {
if (i == j) continue;
mul1 = mul1 * ((k - xi[j] + P) % P) % P;
mul2 = mul2 * ((xi[i] - xi[j] + P) % P) % P;
}
ans = (ans + yi[i] * mul1 % P * fpow(mul2, P - ) % P) % P;
} printf("%lld\n", ans);
return ;
}

最新文章

  1. PhpStorm 集成 开源中国(oschina.net)的Git项目,提交SVN时注意事项
  2. java integer对象判断两个数字是否相等
  3. 【转载】JMeter学习(一)工具简单介绍
  4. bootstrap学习笔记&lt;五&gt;(表单一)
  5. log4j的简单应用(转载)
  6. 富有魅力的git stash
  7. 检查string是否为double
  8. 校友信息管理&amp;SNS互动平台之技术框架选择
  9. POJ_1088 滑雪(记忆型DP+DFS)
  10. c++构造函数谁先执行的问题
  11. Ajax学习(三)——XMLHttpRequest对象的五步使使用方法
  12. Android 将Activity殴打jar包 对于由第三方使用 解决XML 图片 文本资源并不难过进入jar包装问题!
  13. windows7股票的,win8残疾人,安装Han澳大利亚sinoxn个时间,sinox它支持大多数windows软体
  14. Redis持久存储-AOF&RDB
  15. 想要薪资20-30K,Python程序员认真敲代码就够了!
  16. indexer_worker.go
  17. Linux lvs-NAT模式配置详解
  18. 《Effective C++》模板与泛型编程:条款32-条款40
  19. Python——编译标准
  20. 读zepto源码之工具函数

热门文章

  1. 模仿Masonry链式编程思想
  2. 【spring源码学习】spring的事件发布监听机制源码解析
  3. Biology(湖南集训)
  4. android资源目录---assets与res/raw区别
  5. 处理mysql主从中断
  6. Ajax验证用户名
  7. Oracle存储过程使用总结
  8. git 本地文件里内容 操作记录
  9. 【转】性能测试工具JMeter的使用技巧
  10. 【转】Jmeter Http请求界面解释