zoukankan      html  css  js  c++  java
  • 南昌网络赛 H The Nth Item

    南昌网络赛The Nth Item 暴力快速幂+unordered_map记忆化

    注意:记忆化不能写到快速幂求解函数里,不断调用函数会造成很大的时间浪费

    #include<bits/stdc++.h>
    using namespace std;
    #define sc(x) scanf("%lld",&x);
    #define si signed
    #define int long long
    #define P pair<int,int>
    #define fi first
    #define se second
    #define read(A) for(int i=0;i<n;i++) scanf("%lld",&A[i]);
    #define push_back pb
    int A[2][2]={{3,2},{1,0}};
    int B[2][2];
    int C[2][2];
    int D[2][2];
    int Q,N;
    #define mod 998244353
    #define maxn 100000+10
    void mut(int A[][2],int B[][2])
    {
        C[0][0]=((A[0][0]*B[0][0])%mod+(A[0][1]*B[1][0])%mod)%mod;
        C[0][1]=((A[0][0]*B[0][1])%mod+(A[0][1]*B[1][1])%mod)%mod;
        C[1][0]=((A[1][0]*B[0][0])%mod+(A[1][1]*B[1][0])%mod)%mod;
        C[1][1]=((A[1][0]*B[0][1])%mod+(A[1][1]*B[1][1])%mod)%mod;
        for(int i=0;i<=1;i++){
            for(int j=0;j<=1;j++){
                A[i][j]=C[i][j];
            }
        }
    }
    unordered_map<int,int> mp;
    int qp(int n)
    {
        if(n==1)return 1;
        if(n==0)return 0;
        n-=1;
        int Ans[2][2]={{1,0},{0,1}};
        for(int i=0;i<2;i++){
            for(int j=0;j<2;j++){
                B[i][j]=A[i][j];
            }
        }
        while(n){
            if(n&1){
               mut(Ans,B);
            }
            mut(B,B);
            n>>=1;
        }
        return Ans[0][0];
    }
    
    si main()
    {
        scanf("%lld%lld",&Q,&N);
        int ans=0;
        while(Q--){
            int a;
            if(mp[N%499122176]){
             a=mp[N%499122176];   
            }
            else{
                mp[N%499122176]=a=qp(N%499122176);
            }
            ans^=a;
            N=((N^(a*a)));
            
        }
        cout<<ans<<'
    ';
    }
  • 相关阅读:
    配置Log4j(非常具体)
    System.Net.WebClient.cs
    Code:获取指定汉字的首字母
    DBS:目录
    Jasper:推送 API
    Jasper-template
    Code:Base64 编码/解码
    DCloud-HTML5+:5+ App开发入门指南
    DCloud-HTML5+:barcode
    Nuget-QRCode:QRCoder
  • 原文地址:https://www.cnblogs.com/liulex/p/11491616.html
Copyright © 2011-2022 走看看