快速幂应用之剪绳子问题

news2024/11/24 2:20:13

有这样一类问题,给你一个长度为n的绳子,要求你可以剪切任意次数,分为任意段,使得这些子段长度的乘积最大。我们把这类问题暂时先称为剪绳子,这种问题的解法也很简单,通过数学证明可以得出,我们优先剪长度为3的子段,假设剪了x个3后,剩余的长度小于3时,有以下三种情况:

情况一:剩余长度为0,则此时最优,答案为3的x次方。

情况二:剩余长度为1,此时我们应该少剪一个3,即剪切x-1个3,剩余长度为4,此时结果最优,答案为3的x-1次方乘以4。

情况三:剩余长度为2,此时也是最优,答案为3的x次方乘以2。

因此很容易写出代码,这个问题就可以提交了,代码如下

#include <iostream>
using namespace std;
long long M = 1000000007;

int main() {
    long long n;
    cin >> n;
    // x表示的是n分解出来的3的个数
    long long x = n / 3;
    int y = n % 3;  // y表示的是分为x个3后的余数
    /*
     * 如果y=0,则说明刚好分为x个3
     * 如果y=1,则需要调整一下,拿出一个3,和1加起来是4,这样分为x-1个3和1个4是最优解
     * 如果y=2,则x个3和1个2刚好是最优解
     * */
    if (y == 1) {
        y = 4;
        x--;  // 拿出之前分解的一个3,和剩余的一个1组合在一起,这样结果最优
    }
    long long ans = y;
    if (ans == 0) ans = 1;   // 这里防止y=0的情况,如果y为0,则需要将ans置1,因为后面都是乘法运算
    for (int i = 0; i < x; i++) {
        ans *= 3;  // 暴力解决
        if (ans >= M) ans %= M;
    }
    return 0;
}

但是此时又有一个问题,如果给的n特别大,比如,n<=10^18,那么如果用暴力的循环x次求解,则一定会超时,所以此时需要借助快速幂思想来求解。 

思考一下,现在想计算a^b,如何求解,可以第一时间想到库函数,比如c++中,可以通过pow(a, b)计算,但是b特别大,比如b=10^17,此时pow函数肯定会越界,一般对于这种大数量级的幂运算,很容易越界,所以题目会要求你对某个数取余,最常见的是对M=10^9+7取余。所以需要在运算过程中动态对M取余,快速幂的思想是,每次将底数a更新为a*a,指数b减半,过程如下:

第一步:a^{b}=(a^{2})^{\frac{b}{2}}

第二步:我们需要将a^{2}看成一个整体a_{1},把\frac{b}{2}看成一个整体b_{1},继续运用第一步的思想可以得到:(a^{2})^{\frac{b}{2}}=(a_{1})^{b_{1}}=(a_{1}^{2})^{\frac{b_{1}}{2}}

依照上面的步骤,指数每次折半,底数每次变为平方,时间复杂度为logn。

上面有个问题,如果指数为奇数,怎么办?在c++中,比如指数b=7,那么7/2=3,会丢掉一个底数,所以分情况,如果指数为奇数,那么a^{b}=a*(a^{2})^{\frac{b}{2}},如果为偶数,则a^{b}=(a^{2})^{\frac{b}{2}}

代码如下:

#include <iostream>
using namespace std;
long long M = 1000000007;

int main() {
    long long n;
    cin >> n;
    // x表示的是n分解出来的3的个数
    long long x = n / 3;
    int y = n % 3;  // y表示的是分为x个3后的余数
    /*
     * 如果y=0,则说明刚好分为x个3
     * 如果y=1,则需要调整一下,拿出一个3,和1加起来是4,这样分为x-1个3和1个4是最优解
     * 如果y=2,则x个3和1个2刚好是最优解
     * */
    if (y == 1) {
        y = 4;
        x--;  // 拿出之前分解的一个3,和剩余的一个1组合在一起,这样结果最优
    }
    long long ans = y;
    if (ans == 0) ans = 1;   // 这里防止y=0的情况,如果y为0,则需要将ans置1,因为后面都是乘法运算
    
    // 通过快速幂解决超时问题
    long long tmp = 3;  // tmp为上面说的底数,每次循环都会更新为自己的平方,因此tmp的值变化依次为:3,9,27,81,....
    // 在整个过程中,用到快速幂解决超市
    // tmp为底,底会指数增大,x为幂,会指数减少
    while(x > 0) {
        // 对于奇数次幂,如果要多于的底数先与结果ans做运算
        // 注意一个点:对于任何指数b>=2的数字,每次除以2,最终b一定会等于1,那么此时,指数为奇数,会进入if分支,将底数乘给最终结果ans;
        if(x % 2 == 1) {
            ans *= tmp;
            ans %= M;
        }
        x /= 2;
        tmp *= tmp;
        tmp %= M;
    }
    cout << ans;
    return 0;
}

我们拿一个case走一下代码,看看中间过程值分别是多少,比如3^7,此时tmp=3,x=7;

进入代码我们看每次循环的各个变量的值

循环前:x=7,ans=1,tmp=3
第1次循环后:x=3,ans=ans*tmp=3=3^{1},tmp=tmp*tmp=9=3^{3}

第2次循环后:x=1,ans=ans*tmp=27=3^{3},tmp=tmp*tmp=81=3^{4}

第3次循环后:x=0,ans=ans*tmp=2187=3^{7},tmp=tmp*tmp=6561=3^{8}

循环结束,输出ans=2187

有个题目正好用来练手:OnlineJudge

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/645108.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

​Java容器的继承关系​

Java容器的继承关系 Collection接口 Collection接口中所定义的方法 int size(); boolean isEmpty(); void clear(); boolean contains(Object element);//是否包含某个对象 boolean add(Object element); Iterator iterator(); boolean containsAll(Collection c);//是否包含另…

MybatisPlus 实现数据拦截

基于配置文件实现&#xff08;关键key存储在配置文件&#xff0c;通过读取配置文件来实现动态拼接sql&#xff09; 1、创建注解类 UserDataPermission(id"app") 注&#xff1a;id用以区分是小程序还是应用程序 注解加的位置&#xff1a; 2、配置枚举类配置文件 E…

学了Python后还用学R语言吗?

学习R语言是否有必要取决于你的具体需求和背景。虽然R语言和Python都是数据科学领域广泛使用的编程语言&#xff0c;但它们之间还是存在一些差异。 如果你主要从事数据分析、统计建模或者数据可视化等工作&#xff0c;那么学习R语言可能更为适合。R语言在数据处理和统计分析方…

【gcc, cmake, eigen, opencv,ubuntu】四.opencv安装和使用,获取opencv matiax 的指针

文章目录 ubuntu系统安装opencv1.下载opencv和opencv_contrib2.安装指导3.Linux 下 fatal error: opencv2/opencv.hpp: 没有那个文件或目录4.g 和cmake 编译使用opencv的程序5.opencv,eigen速度比较6.opencv常用类型符号7.获取opencv matiax 的指针 ubuntu系统安装opencv 1.下…

Java实训日志03

文章目录 八、项目开发实现步骤&#xff08;五&#xff09;创建数据库连接管理类1、创建数据库实用工具包2、创建数据库连接管理类&#xff08;1&#xff09;定义数据库连接属性常量&#xff08;2&#xff09;创建私有化构造方法&#xff08;3&#xff09;编写获取数据库连接静…

关于C++数组名和指针的一些思考

在学习指针数组与数组指针一节时&#xff0c;了解到数组名其实是指向数组收个元素的指针。如下面代码所示 int main() {int a[5] {1, 2, 3, 4, 5};cout << "*a:" << *a << endl;cout << "*(a 1):" << *(a 1) << e…

注解开发bean

注解开发定义bean 使用component定义bean Component("bookDao") public class BookDaoImpl implements BookDao{} 核心配置文件中通过组件扫描加载bean <context:component-scan base-package"com.tsj"/> Spring提供Component注解的三个衍生注解…

科研人必看 | 学术期刊论文作者署名新规

【SciencePub学术干货】在期刊上发表学术论文&#xff0c;是研究人员发布和传播学术研究成果的重要方式之一。学术期刊论文文献各项著录内容中&#xff0c;作者署名是最主要的组成部分之一。 随着经济的发展和社会的进步&#xff0c;人们面临的科学问题和社会问题日趋复杂&…

KaiwuDB 受邀亮相 IOTE 2023 第十九届国际物联网展

5月17日&#xff0c;IOTE 2023 第十九届国际物联网展在上海拉开序幕&#xff0c;全球超过 350 家参展企业到场展示先进的物联网技术和产品&#xff0c;行业专家、领军企业代表等人物齐聚一堂&#xff0c;共话 IoT 未来趋势。KaiwuDB 受邀亮相参展并就《工业物联网产业数字化转型…

基于SpringBoot+vue的网上图书商城系统设计和实现

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架下…

通用方案px2rem 处理 内联样式、element-ui表头折行、label折行、表单项换行异常

通用方案-处理element-ui 表单项label折行、换行异常&#xff0c;表头折行问题 背景简介&#xff1a;在实际的生产环境中&#xff0c;客户用到的屏幕大大小小分辨率各有异同&#xff0c;但是为了布局的统一和美观&#xff0c;我们采用了postcss-px2rem插件对element-ui进行响应…

仓库拣货标签——仓库16代

6432 全彩 LED 点阵显示屏 ​ 一、产品特性 采用2048 RGB LED全彩显示&#xff0c;亮度可调 无线通信 它可以显示文本、图片或动画 支持24V外置电源 支持系统对接&#xff0c;模板可DIY 二、PTL系统电子标签概述 电子标签拣选系统是利用先进的电子技术和通信技术开发的物…

选择合适的采购系统,实现企业数字化转型

随着数字化技术的飞速发展&#xff0c;企业数字化转型已经成为了当今市场的必然趋势。而采购系统作为企业数字化转型的重要组成部分&#xff0c;选择合适的采购系统对于企业来说至关重要。本文将围绕选择合适的采购系统&#xff0c;实现企业数字化转型展开讨论。 一、企业数字化…

数字门户的创新引擎:小程序容器

小程序容器技术的发展为数字门户带来了许多机会和优势。通过引入第三方生态&#xff0c;数字门户可以快速丰富自身的功能和服务&#xff0c;提高用户留存率&#xff0c;并打造一个开放的生态系统。这种创新的技术手段让数字门户能够更灵活地满足用户多样化的需求&#xff0c;提…

强化学习复现笔记(2)策略迭代

摘要&#xff1a; 上一节的压缩映射在实际迭代时可以分成两种方法&#xff0c;分别称作值迭代和策略迭代。本文用走迷宫的例子&#xff08;将1维迷宫扩展到2维&#xff09;讲这两种迭代。对应第一节参考链接[2]的前4章。 拆分压缩映射 上一节的压缩映射 v f ( v ) vf(v) vf(…

打造科学新高地|2023开放原子全球开源峰会科学智能分论坛圆满举行

6 月 11 日&#xff0c;以“AI 框架助力科学智能&#xff0c;打造科学新高地”为主题的 2023 开放原子全球开源峰会科学智能分论坛在北京圆满举行。北京航空航天大学计算机学院党委书记、教授李建欣参加并致辞&#xff1b;华为昇思 MindSpore 架构师倪宁曦、研究员徐旭升&#…

const用于C++引用(注意事项)

const用于C引用 存在的问题解决方法原理 存在的问题 左值是可以被引用的数据对象&#xff0c;可以通过地址访问它们&#xff0c;例如&#xff1a;变量、数组元素、结构体成员、引用和解引用的指针。 非左值包括字面常量&#xff08;用双引号包含的字符串除外&#xff09;和包含…

公司普通启动VR/AR软件开发虚拟场景游戏

随着元宇宙技术的不断革新&#xff0c;VR作为一种新兴技术&#xff0c;正在迅速普及。VR软件开发技术将用户沉浸到虚拟世界中&#xff0c;让人们可以身临其境地体验一些事物&#xff0c;如元宇宙游戏、商圈、展会、旅游等。而VR虚拟场景的开发&#xff0c;则是实现这一目标的重…

WRF进阶:使用ERA5-land数据驱动WRF/WRF撰写Vtable文件添加气象场

想用WRF模拟地气交换过程&#xff0c;对于WRF的地表数据&#xff0c;尤其是土壤温湿度数据要求便会很大&#xff0c;传统使用ERA5-singledata数据精度也许不足以满足需求&#xff0c;为此&#xff0c;本文尝试使用ERA5-land数据替换驱动WRF。 数据下载 ERA5-land的数据下载与…

2023 届 Java 岗高频面试题盘点,老司机也未必全会

2023&#xff0c;可谓是招聘面试最难季。不少大厂&#xff0c;如腾讯、字节的招聘名额明显减少&#xff0c;面试门槛却一再拔高&#xff0c;如果不用心准备&#xff0c;很可能就被面试官怼得哑口无言。今天不谈其它&#xff0c;就说说我作为面试官面试的那些事儿。 从某电商项…