https://www.luogu.org/problemnew/show/P2293 要求求出给定高精度整数的非负根取整的结果. 还有神仙用Python的浮点pow运算骗到不少分的. 唉! 那么我们使用保险的语言:Java,需要怎么做呢? 高精度数是10的10000次方,他的根应该在10的100次方附近?(题目没说是平方根啊,乱搞!) 我们先读入一个String,数出String有多少位,在这个位数的左右至多4位范围进行二分答案. 自己瞎搞了很久,不是T就是M的,还以为是语言的劣势. 其实是自…
题目:洛谷P2293.BZOJ1213. 题目大意:给你$n,k(n\leq 10^{10000},k\leq 50)$,求$\lfloor \sqrt[k]{n}\rfloor$. 解题思路:高精度+二分+快速幂. 我压了九位. 这题真的卡的我丧心病狂啊!!开始无脑高精度,后来T的不知道哪去了. 首先高精度乘法中除法取模运算特别慢,要放在乘完后再处理. 还有最重要的优化:如果当前的答案的位数乘k减k+1大于n的位数,则不需要进行乘法,因为答案一定失败. 然后尽量减少传值,努力卡常即可. 可怜我…
python是坠吼的! 原题: 不贴原题,就是高精度开根,结果向下取整 首先二分答案,高精度嘛……python即可 二分右端点设为n会T掉,需要先倍增一个r,while(r **m <= n)  r *= 2 然后T掉了,代码如下,亮点自寻 m, n = input(), input() l, r = , n while r ** m < n: r *= < r): md = (l + r) >> if(md ** m <= n): l = md else: r = m…
二次联通门 : BZOJ 1213: [HNOI2004]高精度开根 正解 NTT+高精+倍增+二分 但是可以用python 2333333 m,n=int(raw_input()),int(raw_input()) l,r=0,1 while r**m<=n: l=r;r=r*2 while l+1<r: mid=(l+r)//2 if mid**m<=n: l=mid else: r=mid if r**m<=n: print r else: print l…
晓华所在的工作组正在编写一套高精度科学计算的软件,一些简单的部分如高精度加减法.乘除法早已写完了,现在就剩下晓华所负责的部分:实数的高精度开m次根.因为一个有理数开根之后可能得到一个无理数,所以这项工作是有较大难度的.现在要做的只是这项工作的第一步:只对自然数进行开整数次根,求出它的一个非负根,并且不考虑结果的小数部分,只要求把结果截断取整即可.程序需要根据给定的输入,包括需要开根的次数,以及被开根的整数:计算出它的非负根取整后的结果. Input 共有两行,每行都有一个整数,并且输入中没有多余…
Background\text{Background}Background I've accepted\text{I've accepted}I've accepteda very good problem \text{ a very good problem } a very good problemabout High-Precisions and become\text{about High-Precisions and become}about High-Precisions and b…
锣鼓2293 写完了放代码 应该没什么思维难度 ———————————————————————————————————————————————————————— python真香 m=input() n=input() l=0 r=1 while(r**m<=n): l=r;r=r*2 while(l<=r): mid=(l+r)//2 if(mid**m<=n): l=mid+1 else: r=mid-1 if (l**m<=n): print(l) else: print(r…
这道题直接写了我两个多小时-- 主要是写高精度的时候还存在着一些小毛病,调了很久 在输入这一块卡了很久. 然后注意这里用while的形式写,不然会炸 最后即使我已经是用的万进制了,但是交上去还是有两个点超时 然后就开始漫长的改进,一直过不了那两个点. 然后突然发现,貌似这道题没有涉及到乘法. 那不就可以直接开10的九次方为一位了(10的9次方是int的最大数量级) 我交上去之后就AC了,全部测试点交上去总和4.6秒 然后原来我一个数开的是2500这么大,因为题目给的10000位,之前用万进制除以…
题目描述 用高精度计算出S = 1! + 2! + 3! + - + n!  ( n ≤  50 ) S = 1! + 2! + 3! + - + n! ( n ≤ 50 ) 其中"!"表示阶乘,例如:5! = 5 × 4 × 3 × 2 × 1 输入格式 一个正整数NN. 输出格式 一个正整数S,表示计算结果. 输入输出样例 输入 # 3 输出 # 9   这道题的数据50的阶乘超过了c语言所有数据类型的范围,也就是无法用long long类型,或者unsigned long lon…
题目描述 地球历公元6036年,全宇宙准备竞选一个最贤能的人当总统,共有n个非凡拔尖的人竟选总统,现在票数已经统计完毕,请你算出谁能够当上总统. 输入输出格式 输入格式: 第一行为一个整数n,代表竞选总统的人数. 接下来有n行,分别为第一个候选人到第n个候选人的票数. 输出格式: 共两行,第一行是一个整数m,为当上总统的人的号数. 第二行是当上总统的人的选票. 输入输出样例 输入样例#1: 5 98765 12365 87954 1022356 985678 输出样例#1: 4 1022356…