how to calculate 2^n modulo 1000000007 , n = 10^9

前端 未结 3 1809
傲寒
傲寒 2020-12-11 06:58

what is the fastest method to calculate this, i saw some people using matrices and when i searched on the internet, they talked about eigen values and eigen vectors (no idea

3条回答
  •  北海茫月
    2020-12-11 07:56

    C code for calculating 2^n

        const int mod = 1e9+7;
    
        //Here base is assumed to be 2
        int cal_pow(int x){
            int res;
            if (x == 0) res=1;
            else if (x == 1)    res=2;
            else {
                res = cal_pow(x/2);
                if (x % 2 == 0) 
                    res = (res * res) % mod;
                else
                    res = (((res*res) % mod) * 2) % mod;
            }
            return res;
        }
    

提交回复
热议问题