快速幂(Fast Pow)
定义
快速求a^b%c的算法
原理
指数可以被二进制分解
那么a^b可以分解为a^2^k1*a^2^k2*……
又显然a^2^(k+1)=a^(2^k*2)=(a^2^k)^2
所以可以将指数在二进制下从低位向高位递推,每次将底数平方,若该位是1就将答案乘上底数,直到指数为0。
实现时可以每次将指数/2方便处理
位运算优化
x&1:取x二进制下最后一位
x>>1:x/2
代码
int quickpow(int a,int b,const int c)
{
int base=a%c,ans=;
while(b)
{
if(b&)
ans=ans*base%c;
base=base*base%c;
b>>=;
}
return ans;
}
快速幂
例题
一、序列的第k个数
根据元素之差判断是不是等差数列,不是等差数列即为等比数列
推通项公式时注意序列起始为a
#include<cstdio>
#include<cctype>
using namespace std;
#define re register int
#define ll long long
int stk[],tt;
void print(ll x)
{
if(x==)
putchar('');
else
{
if(x<)
putchar('-'),x=-x;
tt=;
while(x)
{
stk[++tt]=x%;
x/=;
}
for(re i=tt;i;i--)
putchar(stk[i]|);
}
}
int read()
{
int x=,f=;
char c=getchar();
while(!isdigit(c))
{
f|=c=='-';
c=getchar();
}
while(isdigit(c))
{
x=(x<<)+(x<<)+(c^);
c=getchar();
}
return f?-x:x;
}
const int MOD=;
ll quickpow(int a,int b,const int c)
{
ll base=a%c,ans=;
while(b)
{
if(b&)
ans=ans*base%c;
base=base*base%c;
b>>=;
}
return ans;
}
int main()
{
int T=read();
ll a,b,c,k;
while(T--)
{
a=read(),b=read(),c=read(),k=read();
if(b-a==c-b)
print((a+(b-a)*(k-))%MOD);
else
print(a*quickpow(b/a,k-,MOD)%MOD);
putchar('\n');
}
return ;
}
序列的第k个数
二、[NOIP2013]转圈游戏
走10^k轮即移动m*10^k个位置,再加上x取模即可
#include<cstdio>
#include<cctype>
using namespace std;
#define re register int
#define ll long long
int stk[],tt;
void print(int x)
{
if(x==)
putchar('');
else
{
if(x<)
putchar('-'),x=-x;
tt=;
while(x)
{
stk[++tt]=x%;
x/=;
}
for(re i=tt;i;i--)
putchar(stk[i]|);
}
}
int read()
{
int x=,f=;
char c=getchar();
while(!isdigit(c))
{
f|=c=='-';
c=getchar();
}
while(isdigit(c))
{
x=(x<<)+(x<<)+(c^);
c=getchar();
}
return f?-x:x;
}
ll quickpow(int a,int b,const int c)
{
ll base=a%c,ans=;
while(b)
{
if(b&)
ans=ans*base%c;
base=base*base%c;
b>>=;
}
return ans;
}
int main()
{
int n=read(),m=read(),k=read(),x=read();
ll ans=(x+m*quickpow(,k,n))%n;
print(ans);
putchar('\n');
return ;
}
转圈游戏
三、[HNOI2008]越狱
可越狱方案数不好求,但从容斥原理的角度,答案可以表示成总排列数-不可越狱排列数
这两个数都很好求,总排列数=m^n,不可越狱排列数考虑第一个数有m种选法,后面每个数都只有m-1种选法,于是=m*(m-1)^(n-1)
#include<cstdio>
#include<cctype>
using namespace std;
#define re register int
#define ll long long
int stk[],tt;
void print(int x)
{
if(x==)
putchar('');
else
{
if(x<)
putchar('-'),x=-x;
tt=;
while(x)
{
stk[++tt]=x%;
x/=;
}
for(re i=tt;i;i--)
putchar(stk[i]|);
}
}
ll read()
{
ll x=;
int f=;
char c=getchar();
while(!isdigit(c))
{
f|=c=='-';
c=getchar();
}
while(isdigit(c))
{
x=(x<<)+(x<<)+(c^);
c=getchar();
}
return f?-x:x;
}
const int MOD=;
ll quickpow(int a,ll b)
{
ll base=a%MOD,ans=;
while(b)
{
if(b&)
ans=ans*base%MOD;
base=base*base%MOD;
b>>=;
}
return ans;
}
inline int mod(ll a)
{
a%=MOD;
if(a<)
a+=MOD;
return a;
}
int main()
{
ll m=read(),n=read();
print(mod(quickpow(m,n)-m*quickpow(m-,n-)));
putchar('\n');
return ;
}
越狱
注意事项
1、根据题目数据范围适当修改快速幂函数中数据的类型
2、取模的数可能<0时注意实际意义
快速幂(Fast Pow)的更多相关文章
- hdu 1757 矩阵快速幂 **
一看正确率这么高,以为是水题可以爽一发,结果是没怎么用过的矩阵快速幂,233 题解链接:点我 #include<iostream> #include<cstring> ; us ...
- HUST 1569(Burnside定理+容斥+数位dp+矩阵快速幂)
传送门:Gift 题意:由n(n<=1e9)个珍珠构成的项链,珍珠包含幸运数字(有且仅由4或7组成),取区间[L,R]内的数字,相邻的数字不能相同,且旋转得到的相同的数列为一种,为最终能构成多少 ...
- A Simple Math Problem(矩阵快速幂)(寒假闭关第一题,有点曲折啊)
A Simple Math Problem Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- hdu4965 Fast Matrix Calculation (矩阵快速幂 结合律
http://acm.hdu.edu.cn/showproblem.php?pid=4965 2014 Multi-University Training Contest 9 1006 Fast Ma ...
- LeetCode 50 - Pow(x, n) - [快速幂]
实现 pow(x, n) ,即计算 x 的 n 次幂函数. 示例 1: 输入: 2.00000, 10输出: 1024.00000 示例 2: 输入: 2.10000, 3输出: 9.26100 示例 ...
- LeetCode Pow(x, n) (快速幂)
题意 Implement pow(x, n). 求X的N次方. 解法 用正常的办法来做是会超时的,因为可能有21亿次方的情况,所以需要优化一下.这里用到了快速幂算法,简单来说就是将指数分解成二进制的形 ...
- HDU4965 Fast Matrix Calculation —— 矩阵乘法、快速幂
题目链接:https://vjudge.net/problem/HDU-4965 Fast Matrix Calculation Time Limit: 2000/1000 MS (Java/Othe ...
- hdu4965 Fast Matrix Calculation 矩阵快速幂
One day, Alice and Bob felt bored again, Bob knows Alice is a girl who loves math and is just learni ...
- HDU - 4965 Fast Matrix Calculation 【矩阵快速幂】
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4965 题意 给出两个矩阵 一个A: n * k 一个B: k * n C = A * B M = (A ...
随机推荐
- mysql添加字段索引失败 BLOB/TEXT column 'col2' used in key specification without a key length
看了下该表的数据结构发现col2字段类型是text ,查询了下发现是:MySQL只能将BLOB/TEXT类型字段设置索引为BLOB/TEXT数据的钱N个字符.索引指定下col2的长度就可以了 : al ...
- Spring+hibernate 配置实例
转自:http://www.cnblogs.com/hongten/archive/2012/03/10/java_spring_hibernate.html 项目结构: http://www.cnb ...
- 爬虫二之Requests
requests 实例引入 import requests response = requests.get('https://www.baidu.com') response.status_code ...
- 关于BeautifulSoup4 解析器的说明
一.解析器概述 如同前几章笔记,当我们输入: soup=BeautifulSoup(response.body) 对网页进行析取时,并未规定解析器,此时使用的是python内部默认的解析器“html. ...
- Oracle 高版本往低版本备份恢复的方法
1. 高版本的数据库备份恢复到低版本的数据库 有时候回报错, 提示version版本不一致, 2. 其实方法是expdp 导出的时候 增加一个参数就可以了 参数 一般的类型是 version=11.2 ...
- MySQL服务意外停止
先说一下,发现MySQL服务停了,启动就又好了,但是好奇服务意外停止的原因,所以看了一下MySQL的错误日志. 但是到底是哪个错误导致MySQL服务意外终止,还没有定论,故有了此篇文章,还望知道原因的 ...
- Spring Boot 深度调优,6得飞起~
项目调优 作为一名工程师,项目调优这事,是必须得熟练掌握的事情. 在SpringBoot项目中,调优主要通过配置文件和配置JVM的参数的方式进行. 一.修改配置文件 关于修改配置文件applicati ...
- Node+Express+MySql实现简单增删改查和登录
var express = require('express'); var mysql = require('mysql'); var app = express(); var bodyParser ...
- mysql,oracle,sql server数据库默认的端口号,端口号可以为负数吗?以及常用协议所对应的缺省端口号
mysql,oracle,sql server数据库默认的端口号? mysql:3306 Oracle:1521 sql server:1433 端口号可以为负吗? 不可以,端口号都有范围的,0~65 ...
- 如何在github上部署自己的前端项目
很多时候我们想需要一个地址就可以访问自己的前端作品, 但是注册一个服务器和域名是需要花钱,很多小伙伴都不愿意, 其实这种前端静态页面github就可以帮我们预览其效果,而且只要在有网的情况下都可以访问 ...