2016 百度之星资格赛

A

前缀的积可以求出来  然后 z[b]/z[a-1]   就是要求的   求一下 z[a-1]的逆元   m为素数 可以用费马小定理

#include<stdio.h>
#include<algorithm>
#include<cstring>
#include<string>
#include<cmath>
#include<vector>
#include<queue>

using namespace std;

#define LL   __int64
#define MAXN 200010
#define inf  1000000000

char z[MAXN];
int  sum[MAXN];

int quick(int a,int b,int c)
{
    int ans=1;
    a=a%c;
    while(b>0)
    {
        if(b%2==1)
            ans = (ans *a)%c;
        b>>=1;
        a = (a*a)%c;
    }
    return ans;
}
int main()
{
    int n;
    int m=9973;

    while(scanf("%d",&n)!=EOF)
    {
        scanf("%s",z+1);
        int len=0;
        for(int i=1;z[i];i++)
            len++;
        sum[0]=1;
        for(int i=1;i<=len;i++)
            sum[i]=(sum[i-1]*(z[i]-28))%m;

        for(int i=1;i<=n;i++)
        {
            int a,b;
            scanf("%d%d",&a,&b);
            int nia =quick(sum[a-1],m-2,m);
            printf("%d\n",(sum[b]*nia)%m);
        }
    }
    return 0;
}

B  斐波那契数列  果断Java

import java.math.*;
import java.util.*;
import java.lang.*;

public class Main {

    public  static void main(String argc[])
    {
        Scanner x =new Scanner(System.in);
        
        BigInteger z[]= new BigInteger [205];
        int c=1;
        z[0]=BigInteger.valueOf(c);
        z[1]=BigInteger.valueOf(c);
        for(int i=2;i<=200;i++)
        {
            z[i]=BigInteger.ZERO;
            z[i]=z[i].add(z[i-2]);
            z[i]=z[i].add(z[i-1]);
        }
        
        while(x.hasNext())
        {
            int a=x.nextInt();
            System.out.println(z[a]);
        }
    }
}
View Code

 

posted on 2017-03-19 15:55  HelloWorld!--By-MJY  阅读(321)  评论(0编辑  收藏  举报

导航