【个人学习记录】快速幂算法/位运算 [ZCMU OJ]1202: 3的幂的和1417: 2048

2024-01-19 06:38

本文主要是介绍【个人学习记录】快速幂算法/位运算 [ZCMU OJ]1202: 3的幂的和1417: 2048,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Description

求:3^0 + 3^1 +...+ 3^(N) mod 1000000007。

Input

每行一个整数N(0 <= N <= 10^9)

Output

输出:计算结果

Sample Input

3

Sample Output

40

HINT

(a/b)%c=(a%(b*c))/b (a 能整除b)

---------------------------------------------------------------------------------------------------------------------------------

写点废话:今天看《数据结构与算法分析》p26-27,其中提到幂运算。刚好想到了快速幂算法(虽然我听说过这个算法但当时并不会),结果我以为书上的取幂运算就是针对这道题的最优算法,想现学现用一下。结果发现要么tle要么wa,折腾了好久。。。最最开始遇到这个题目用的for循环(当然这肯定超时了)。。既然要解决这道题那么就要涉及到数据结构,我就上网学习了一波快速幂算法。

---------------------------------------------------------------------------------------------------------------------------------

书上的取幂运算计算X^N运用到了递归思想,指数为0则结果返回1,指数为1则返回X本身。如果指数是偶数,则将X^N变为X^(N/2)*X^(N/2);是奇数则将X^N变为X^(N/2)*X^(N/2)*X;所需要的乘法次数最多是2logN。

long int Pow(long int X,unsigned int N)
{if(N==0)return 1;else if(N==1)return X;if(N%2==0)return Pow(X*X,N/2);elsereturn Pow(X*X,N/2)*X;
}

 按照相同的思路以及我通过学习之后的理解,我把最初用for暴力循环替换成了如下代码(其中maxn=1e9+7);底数平方,指数减半;若指数为奇数则减去1使指数为偶数再除以2。

long long qp(long long base,long long power)
{long long result=1;while(power>0){if(power%2==0){base=(base*base)%maxn;power/=2;	}else{power--;result=(result*base)%maxn;power/=2;base=(base*base)%maxn;}}return result;
}

假设计算x^43,程序如下运行:

尽管如此,程序依然超时了。那么可以利用位运算替换一些语句。

power%2==1 可替换为 power&1 (与运算)

power/=2 可替换为 power>>=1(将power的二进制位向右移动一位则可使power变为原来的一半)

再次优化,其中求和利用等比数列求和公式 Sn = ( a1*(1-q^n) )/(1-q) 即可。a1=1,q=3;

注意:除以一个数mod另一个数等于乘以这个数的逆元。

学习并掌握核心思路再把思路翻译为代码如下:

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e9+7;
long long qp(long long power)
{long long result=1,base=3;while(power>0){if(power&1){result=(base*result)%maxn;}power>>=1;base=(base*base)%maxn;}return result;
}
int main()
{long long n;while(cin>>n){cout<<(qp(n+1)-1)*(500000004)%maxn<<endl;}
}

注意:对于取余运算,(a/b)%c != (a%c / b%c) %c;

(a/b)%c=(a%(b*c))/b (a 能整除b)

---------------------------------------------------------------------------------------------------------------------------------

Description

想必大家都玩过2048的游戏,小明想知道这个游戏能出现的最高数字是多少?请你帮忙计算,当然小明玩的2048和我们的不太一样,小明的2048不一定是4X4的格子,可以使3X2等等。小明的2048只能随机生成2。

Input

输入n,m(0<=n,m<=10^4)表示有2048游戏矩阵的大小,当0,0时结束;

Output

输出理论最大值,答案对1000000007取余。

Sample Input

2 2 0 0

Sample Output

16
---------------------------------------------------------------------------------------------------------------------------------
思路同理,注意m或n等于0的情况,上ac代码:
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e9+7;
long long QuickPower(long long base,long long power)
{long long result=1;while(power>0){if(power&1){result=result*base%maxn;}power>>=1;base=(base*base)%maxn;}return result;
}
int main()
{long long n,m;while(~scanf("%lld %lld",&n,&m)&&(n!=0||m!=0)){if(n==0||m==0)cout<<"0"<<endl;elsecout<<QuickPower(2,(m*n)%maxn)<<endl;}
}

这篇关于【个人学习记录】快速幂算法/位运算 [ZCMU OJ]1202: 3的幂的和1417: 2048的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/621548

相关文章

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Mybatis-Plus 3.5.12 分页拦截器消失的问题及快速解决方法

《Mybatis-Plus3.5.12分页拦截器消失的问题及快速解决方法》作为Java开发者,我们都爱用Mybatis-Plus简化CRUD操作,尤其是它的分页功能,几行代码就能搞定复杂的分页查询... 目录一、问题场景:分页拦截器突然 “失踪”二、问题根源:依赖拆分惹的祸三、解决办法:添加扩展依赖四、分页

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤