http://acm.hdu.edu.cn/showproblem.php?pid=4927

给定一个长度为n的序列a,每次生成一个新的序列,长度为n-1,新序列b中bi=ai+1−ai,直到序列长度为1.输出最后的数。

n有3000果断用大数,类似杨辉三角推出每个数对最终结果的贡献,利用公式:c[n][m] = c[n][m-1]*(n-m+1)/m防超时

import java.math.BigInteger;
import java.util.*; public class Main
{
public static void main(String args[])
{
Scanner cin = new Scanner(System.in);
int _ = cin.nextInt();
BigInteger[] t = new BigInteger[3005];
while(true)
{
if(_==0)
break;
_--;
int n = cin.nextInt();
for(int i = 1;i <= n;++i)
t[i] = cin.nextBigInteger();
BigInteger ans = BigInteger.ZERO;
BigInteger s = BigInteger.ONE;
int flag = n%2;
for(int i = 1;i <= n;++i){
if(i%2 == flag)
ans = ans.add(s.multiply(t[i]));
else
ans = ans.subtract(s.multiply(t[i]));
s = s.multiply(BigInteger.valueOf(n - i)).divide(BigInteger.valueOf(i));
}
System.out.println(ans);
}
}
}

最新文章

  1. webapi returntype
  2. oracle基本操作符/运算符/操作语言
  3. const用法小结
  4. C++模板常用使用方法介绍
  5. 嵌入式Linux C笔试题积累(转)
  6. 如何查看跟踪查看LINUX内核中的源码
  7. OpenGL ES 2.0 shader开发
  8. Java多线程的wait(),notify(),notifyAll()
  9. android获取ip和本机的物理地址
  10. 1592: [Usaco2008 Feb]Making the Grade 路面修整
  11. Java之数据类型,变量赋值
  12. LNMP搭建环境遇到的N多坑
  13. SpringMVC+MyBatis+Druid使用MySQL8.0.11版本
  14. KVM虚拟化原理与基础应用示例
  15. 【手记】sql报“聚合或其他set操作消除了null值”处理
  16. 【九天教您南方cass 9.1】 04 编码法Ⅱ绘制地形图
  17. Centos 7系统挂载NTFS格式移动硬盘
  18. pt-table-checksum工具MySQL主从复制数据一致性
  19. Xcode下修改plist文件
  20. JavaScript中的callee与caller的区别

热门文章

  1. iOS.CM5.CM4.CM2
  2. LIbreOJ #6011. 「网络流 24 题」运输问题 最小费用最大流
  3. MySQL学习笔记-数据库内存
  4. Raw Socket(原始套接字)实现Sniffer(嗅探)
  5. compatible with
  6. HashMap 、HashTable、TreeMap、WeakHashMap的区别是什么
  7. 软件测试基础Ⅲ(osi7层协议,测试模型,LoadRunner组件,软件质量模型)
  8. jdom解析xml
  9. 【转】先说IEnumerable,我们每天用的foreach你真的懂它吗?
  10. lambda表达式和表达式树(深入理解c#)