hdu 5351 规律+大数

时间:2024-01-16 18:38:14

题目大意:定义了一种fib字符串,问第n个fib串的前m个字母前后相等串的最大长度,大约就是这样的

其实主要读完题意的时候并没有思路,但是列几个fib字符串就会发现,除了fib1以外,所有串的前面都是一样的,后面的串就只是在前面串的基础上再贴一个串而已,因此很明显,这里的n其实读下来并没有什么用,基本只是用来告诉我们总串长是第1000个fib数列的数,因此要大数,我就试着写了java大数。然后这个结果就直接列一些,打表就会发现规律了```然后就没有然后了。恩,别忘了mod

 import java.math.BigInteger;
import java.util.*;
import java.io.*;
public class Main{
static BigInteger fib[] = new BigInteger[1005];
static BigInteger Mod=new BigInteger("258280327");
public static void init(){
fib[1]=new BigInteger("1");
fib[2]=new BigInteger("1");
for(int i=3;i<=1000;++i){
fib[i]=fib[i-1].add(fib[i-2]);
}
}
public static void main(String[] args){
Scanner input = new Scanner(System.in);
init();
int T=input.nextInt();
while(T--!=0){
int n=input.nextInt();
BigInteger m=input.nextBigInteger();
m=m.add(BigInteger.ONE);
int i;
for(i=1;i<=1000;++i){
int f=m.compareTo(fib[i]);
if(f<0)break;
}
System.out.println((m.subtract(fib[i-2].add(BigInteger.ONE))).mod(Mod));
}
input.close();
}
}

java大数还是非常好的恩```