Coefficient Computation (大整数、Java解决)
Coefficient Computation UVALive8265
题意:计算组合数C(n,k)的值并将值按给定的进制输出。
思路:Java大整数类硬上。
PS:刚刚学完Java的大整数类,结果却被Java怎么开数组卡到吐血,直接后果就是少开一题,赛后学长指导后5分钟出题,真酸爽……
- 包:java.math.*
- BigInteger类实现了任意精度的整数运算。
- BigDecimal类实现了任意精度的浮点数运算。
- 读入大整数a:Scanner in = new Scanner(System.in); BigInteger a; a = in.nextBigInteger();
定义大整数类BigInteger a,b;
- 静态valueOf方法可以将普通的数值转换为大数值:BigInteger a = BigInteger.valueOf(100)
- 大整数的相加a = a.add(b);表达式为a =a+ b;
- 大整数的相减a = a.subtract(b);表达式为 a = a - b;
- 大整数的相乘a = a.multiply(b);表达式为 a = a * b;
- 大整数的相除a = a.divide(b);表达式为 a = a / b;
- 大整数的取余a = a.mod(b);表达式为 a = a % b;
- 大整数的比较a.compareTo(b);如果a与b相等则返回0,如果a大于b返回正数,如果a小于b返回 负数;
- a.valueOf(100);返回值为100的大整数;
- 将字符串转换成10进制大整数类型:String s = "100000000000000000000000000000000" ,BigInteger c = new BigInteger(s,10)
- 其他操作:a.pow(b) = a^b;a.gcd(b) = a和b的最大公约数;a.abs() = a的绝对值;a.negate() = a的取反数;max(),min();
- System.out.println(a.toString(d));将大整数a按d进制输出;
大实数类的运算(实现方法与大整数一样):
- BigDecimal add(BigDecimal other)相加
- BigDecimal subtract(BigDecimal other)相减
- BigDecimal multiply(BigDecimal other)相乘
- BigDecimal divide(BigDecimal other RoundingMode mode) 5.0 相除,必须给出舍入方式RoundingMode.HALF_UP是在学校学习的四舍五入方式
- BigDecimal compareTo(BigDecimal other)比较返回值和大整数一样,见上边
- static BigDecimal valueOf( long x) 返回值为x的大实数
- static BigDecimal valueOf(long x,int scale)返回值为x / 10的scale次方的大实数
好了上代码:
import java.math.*;
import java.util.*; public class Main
{
public static void main(String[] args)
{
Scanner in = new Scanner(System.in);
int n,k,d,t;
t = in.nextInt();
for(int o = ; o < t; o++)
{
n = in.nextInt();
k = in.nextInt();
d = in.nextInt();
if(n == || k == )
System.out.println();
else
{
BigInteger big = BigInteger.valueOf(n);
for(int i = n-; i >= n-k+; i--)
{
big = big.multiply(BigInteger.valueOf(i));
}
BigInteger lit = BigInteger.valueOf(k);
for(int i = k-; i > ; i--)
{
lit = lit.multiply(BigInteger.valueOf(i));
}
BigInteger ans = big.divide(lit);
BigInteger[] temp = new BigInteger[];//!!!!!!!!!!!!!!!!!!!!!!!!!开数组
BigInteger dd = BigInteger.valueOf(d);
int index = ;
while(true)
{
if(ans.compareTo(BigInteger.valueOf()) == ) break;
temp[index++] = ans.mod(dd);
ans = ans.divide(dd);
}
for(int i = index-; i>=; i--)
System.out.print(temp[i]);
System.out.println();
}
}
}
}
大整数类也是一个封装好的类,所以可以开数组,但要注意开数组的格式。
Coefficient Computation (大整数、Java解决)的更多相关文章
- 算法笔记_159:算法提高 第二大整数(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 编写一个程序,读入一组整数(不超过20个),当用户输入0时,表示输入结束.然后程序将从这组整数中,把第二大的那个整数找出来,并把它打印出来 ...
- 【BZOJ】3751: [NOIP2014]解方程【秦九韶公式】【大整数取模技巧】
3751: [NOIP2014]解方程 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 4856 Solved: 983[Submit][Status ...
- java 常用类库:BigInteger大整数;BigDecimal大小数(解决double精度损失);
大整数BigInteger package com.zmd.common_class_libraries; import java.math.BigInteger; /** * @ClassName ...
- 【Java编程】Java中的大整数计算
在上一篇文章中,我们实现了c语言中的大整数的运算,并且用Miller-Rabin算法实现了对大素数的测试.本来我准备用Java代码实现大整数的运算,查了一下资料发现Java中java.math的Big ...
- 大整数相乘问题总结以及Java实现
最近在跟coursera上斯坦福大学的算法专项课,其中开篇提到了两个整数相乘的问题,其中最简单的方法就是模拟我们小学的整数乘法,可想而知这不是比较好的算法,这门课可以说非常棒,带领我们不断探索更优的算 ...
- Java开发笔记(二十九)大整数BigInteger
早期的编程语言为了节约计算机的内存,给数字变量定义了各种存储规格的数值类型,比如字节型byte只占用一个字节大小,短整型short占用两个字节大小,整型int占用四个字节大小,长整型long占用八个字 ...
- suseoj 1207: 大整数的乘法(java, 大数相乘, C/C++, 大数相乘)
1207: 大整数的乘法 时间限制: 1 Sec 内存限制: 128 MB提交: 7 解决: 2[提交][状态][讨论版][命题人:liyuansong] 题目描述 求两个不超过200位的非负整数 ...
- 自己动手写Java大整数《3》除法和十进制转换
之前已经完毕了大整数的表示.绝对值的比較大小.取负值.加减法运算以及乘法运算. 详细见前两篇博客(自己动手写Java * ). 这里加入除法运算. 另外看到作者Pauls Gedanken在blog( ...
- 【老鸟学算法】大整数乘法——算法思想及java实现
算法课有这么一节,专门介绍分治法的,上机实验课就是要代码实现大整数乘法.想当年比较混,没做出来,颇感遗憾,今天就把这债还了吧! 大整数乘法,就是乘法的两个乘数比较大,最后结果超过了整型甚至长整型的最大 ...
随机推荐
- 模块化开发(二)--- seaJs入门学习
SeaJS是一个基于CMD模块定义规范实现一个模块系统加载器 [CMD规范](https://github.com/cmdjs/specification/blob/master/draft/mo ...
- MapReduce的矩阵相乘
一.单个mapreduce的实现 转自:http://blog.sina.com.cn/s/blog_62186b460101ai1x.html 王斌_ICTIR老师的<大数据:互联网大规模数据 ...
- java 多线程——同步 学习笔记
一.实例的同步方法 public synchronized void add(int value){ this.count += value; } Java 实例方法同步是同步在拥有该方法的对象上 ...
- TeeChart绘图控件 - 之三 - 提高绘图的效率 .
TeeChart是个很强大的控件,其绘图能力之强,其他控件难以比拟,但是有个问题就是他的绘图速度,其实TeeChart绘图速度还是很快的,只是大家一直都没正确运用其功能所以导致绘图速度慢的假象. 下面 ...
- NodeJs函数式编程
虽然标题是NodeJS函数式编程,但实际上NodeJS 是一个框架,不是一种语言,其采用的语言是 JavaScript.而JavaScript是一种典型的多范式编程语言,算不上是函数式语言,但它有函数 ...
- bzoj1098
并查集+dfs 先开始想和不相连的点用并查集连起来,最后看每个连通块有多少个点就行了,但是这样是O(n*n)的,然而我并没有想到补图 其实就是求补图有多少连通块,因为补图中两个点有边,那么这两个点必须 ...
- handbook/CentOS/使用免费SSL证书让网站支持HTTPS访问.md
- 【转载】[Oracle] Linux下手动创建数据库过程
今天发现一个Oracle测试库的字符集设置不正确,原本的字符集是UTF-8,正确的字符集应该是ZHS16GBK,因为UTF-8是ZHS16GBK的超集,无法修改,只能重建数据库,幸好该测试库上还没有数 ...
- pcntl研究
虽说php用于并发计算有点山寨,但总比没有强把.(有问题请指正) 下面是pcntl多线程的例子.(只能用于cli模式,而且只能用于linux环境) <?php $starttime=microt ...
- [App Store Connect帮助]三、管理 App 和版本(2.7)输入 App 信息:添加 iMessage 信息版 App 的 App 信息
您可以使用 Messages framework(Messages 框架)来创建贴纸包或 iMessage 信息版 App(可在 iMessage App Store 中获取).可作为独立 App,也 ...