Super Pow

原创 2016年08月30日 09:48:54

前提知识: ab % k = (a%k)(b%k)%k

对b做二分处理,即 (a^b) % k = (a * a)^(b/2) % k,这样时间复杂度就是logb了

当然还要处理b是奇数的情况,而且b在这道题里是个数组,所以要写一些针对数组的运算函数

class Solution {
public:
	int superPow(int a, vector<int>& b) {
		int ans = 1;
		a = a % 1337;
		while (morethanzero(b))
		{
			if (IsOdd(b))
				ans = (ans * a) % 1337;
			div(b, 2);
			a = (a * a) % 1337;
		}
		return ans;
	}

	void div(vector<int> &x, int y)
	{
		int tmp = 0;
		for (int i = 0; i < x.size(); i++)
		{
			x[i] += tmp * 10;
			tmp = x[i] % y;
			x[i] = x[i] / y;
		}
	}

	bool IsOdd(const vector<int> & nums)
	{
		if (nums.back() & 1)
			return true;
		else
			return false;
	}

	bool morethanzero(vector<int> & x) {
		for (int i = x.size() - 1; i >= 0; i--) {
			if (x[i] > 0) return true;
		}
		return false;
	}
};
然而还是超时了,囧,因为每次做除法的时候都要遍历一遍数组,所以时间复杂度实际上是nlogb

最后用了官方discuss里的一份代码,简单解释一下:

a^1234567 % k = (a^1234560 % k) * (a^7 % k) % k = (a^123456 % k)^10 % k * (a^7 % k) % k

写成函数的形式就是:f(a,1234567) = f(a, 1234560) * f(a, 7) % k = f(f(a, 123456),10) * f(a,7)%k

所以用迭代的方法进行计算

class Solution {
    const int base = 1337;
    int powmod(int a, int k) //a^k mod 1337 where 0 <= k <= 10
    {
        a %= base;
        int result = 1;
        for (int i = 0; i < k; ++i)
            result = (result * a) % base;
        return result;
    }
public:
    int superPow(int a, vector<int>& b) {
        if (b.empty()) return 1;
        int last_digit = b.back();
        b.pop_back();
        return powmod(superPow(a, b), 10) * powmod(a, last_digit) % base;
    }
};



leetcode 336. Palindrome Pairs 372. Super Pow

336. Palindrome Pairs题目大意给你n个字符串,选出任意两个不同的字符串i和j,其拼接后是否为回文子串,返回所有可能的小标组合。思路一直接遍历所有可能的组合,并判断是否为回文子串,其...

LeetCode--372. Super Pow

LeetCode–372. Super Pow

[java][leetcode 372]Super Pow

Your task is to calculate ab mod 1337 where a is a positive integer and b is an extremely large posi...
  • ghui23
  • ghui23
  • 2016年07月22日 16:48
  • 297

372. Super Pow

Your task is to calculate ab mod 1337 where a is a positive integer and b is an extremely large pos...
  • Tomjx
  • Tomjx
  • 2017年05月22日 00:10
  • 86

Pow(x, n) / Super Pow

题目分析 1. Pow(x, n)这题和Super Pow这题非常相似,都是要用快速幂的方法来完成的,因此放在一起来考虑。 2. Pow(x, n)这题第一次提交的时候我用的是非常简单的写法,直接...
  • mahua23
  • mahua23
  • 2017年01月17日 10:56
  • 94

pow2WebGUIJava工具包源码

  • 2005年03月17日 12:51
  • 0B
  • 下载

[区块链]共识算法(POW,POS,DPOS,PBFT)介绍和心得

POW:Proof of Work,工作证明。比特币在Block的生成过程中使用了POW机制,一个符合要求的Block Hash由N个前导零构成,零的个数取决于网络的难度值。要得到合理的Block H...
  • lsttoy
  • lsttoy
  • 2017年03月12日 18:31
  • 15189

Pow(x, n) 求一个数的n次方

我们知道C++中是有pow函数的,我们这次自己来写个,因为有这样的算法题目。 所需数学知识: 大致考虑正数,0,负数即可。n多个数相乘的问题。 1.简单For循环 这还不简单,马上写一个f...

探索c++的函数pow()的实现方法·数学与程序设计的结合(zz)

计算t的m次幂的方法:(探索c++的函数pow()的实现方法,数学与程序设计的结合) 源程序下载:http://pjy.studio.googlepages.com/powP.cpp 或到我的收藏...

Blockchain的鱼和熊掌系列(10)PoW协议

A proof-of-work (PoW) is a computing result which is difficult to work out but easy for others to ve...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Super Pow
举报原因:
原因补充:

(最多只允许输入30个字)