C++ 算法学习——1.8 快速幂算法

背景知识:

1.位运算

在C++中,位运算是对整数类型的位进行操作的一种运算方式。常见的位运算符包括按位与(&)、按位或(|)、按位异或(^)、取反(~)、左移(<<)和右移(>>)等。这些运算符可以用来对整数的二进制表示进行操作,实现一些特定功能。下面是对常见位运算操作的简要解释:

  1. 按位与(&):将两个数的对应位都为1的情况下得到1,否则为0。

    例如:5 & 3 的结果是 1,因为 5 的二进制表示是 1013 的二进制表示是 011,按位与后得到 001,即 1

  2. 按位或(|):将两个数的对应位只要有一个为1就得到1,否则为0。

    例如:5 | 3 的结果是 7,因为 5 的二进制表示是 1013 的二进制表示是 011,按位或后得到 111,即 7

  3. 按位异或(^):将两个数的对应位相异时得到1,相同时得到0。

    例如:5 ^ 3 的结果是 6,因为 5 的二进制表示是 1013 的二进制表示是 011,按位异或后得到 110,即 6

  4. 取反(~):对操作数的每一位取反(0变1,1变0)。

    例如:~5 的结果是 -6,因为 5 的二进制表示是 000...0101,取反后得到 111...1010,这是补码表示,转换为十进制即为 -6

  5. 左移(<<):将一个数的二进制表示向左移动指定的位数。

    例如:5 << 1 的结果是 10,因为将 5 的二进制表示 101 向左移动一位得到 1010,即 10

  6. 右移(>>):将一个数的二进制表示向右移动指定的位数。

    例如:5 >> 1 的结果是 2,因为将 5 的二进制表示 101 向右移动一位得到 10,即 2

 2.快速幂的原理

快速幂算法的基本思想是利用二进制分解来减少运算次数。具体步骤如下:

  1. 将指数 n 转化为二进制形式。
  2. 从二进制形式的最低位开始,依次检查每一位:
    • 如果该位为 1,则乘以当前的幂值 base
    • 如果该位为 0,则不进行乘法操作。
  3. 每次处理完一位,将底数 base 自乘一次,表示底数的幂次增加一倍。
  4. 继续处理下一位,直到处理完所有位。

 举个例子:

计算 3^5,以下是上述抽象过程的演示:

  1. 首先,将指数 5 转换为二进制形式:5 的二进制表示为 101。

  2. 从二进制形式的最低位开始逐位处理:

    • 初始时,底数为 3,ans为 1。
    • 第一位为 1,ans乘以当前的幂值 3:结果为 3。base自乘一次为9。
    • 第二位为 0,不进行乘法操作,底数自乘一次:底数变为81,ans不动。
    • 第三位为 1,ans乘以当前的底数81,ans变为3×81=243。

其次引入核心问题。

P1. 洛谷p1226快速幂

long long fastPowerMod(long long base, long long exponent, long long c) {
    long long result = 1;
    
    base = base % c;  // Take base mod c to handle large base values
    
    while (exponent > 0) {
        if (exponent & 1) {  // Check if the current bit is 1
            result = (result * base) % c;
        }
        
        base = (base * base) % c;  // Square the base and take mod c
        exponent = exponent >> 1;  // Shift the bits of the exponent to the right
    }
    
    return result;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

芯课堂 | Synwit_UI_Creator(μgui)平台之图像处理篇

今天小编给大家介绍的是UI_Creator&#xff08;μgui&#xff09;平台下关于图像处理的选项。 UI_Creator&#xff08;μgui&#xff09;平台图片类控件有图像控件和分级图像控件&#xff0c;均包含以下选项&#xff1a; 1、消除水波纹&#xff1a; 由于16位真彩色&#xff08…

基础IO -- 理解文件(1)

目录 一&#xff1a;回顾文件 二&#xff1a;加深对文件的理解 1.概念 2.以w写方式打开 3.以a追加方式打开 4.重定向 一&#xff1a;回顾文件 以前学习过在C语言中的文件操作&#xff0c; 但那根本是不足以理解文件的&#xff0c;即站在语言角度是不可能理解文件的 我们要…

QT 中如何保存matlab 能打开的.mat数据矩阵!

Windows 上安装并使用 MATIO 库来保存 MATLAB 格式的 .mat 文件&#xff0c;需要进行以下步骤&#xff1a; 1. 下载并安装 CMake MATIO 使用 CMake 构建项目&#xff0c;因此你需要先安装 CMake。 前往 CMake 官网下载适用于 Windows 的安装程序并安装。 2. 下载 MATIO 库源…

说下SSL/TLS四次握手过程?

参考自&#xff1a;SSL/TLS四次握手过程是怎么样的&#xff1f;HTTPS、SSL、TLS三者之间的联系和区别 一.SSL/TLS 简介 SSL(Secure Socket Layer 安全套接层)是基于 HTTPS 下的一个协议加密层&#xff0c;用于解决 HTTP 在传输数据时使用明文而导致的不安全问题。 SSL 是 HT…

AD报错failed to add class member\net

什么原因导致的我到现在还没弄懂&#xff0c;总之解决方法是在PCB端删除所有现有的并且可删除的nets与components。下次问题复现了再补充截图&#xff08;不想再遇到了球球了这种玄学问题&#xff09;。 网络截图&#xff1a; 解决步骤&#xff1a;设计->类 把可删除的网络…

西门子828d的plc一些信息记录

1、虽然是200的plc但是引入了DB的形式替代原来的V存储区。 2、用户自定义DB块范围&#xff0c;DB9000-DB9063,共64个DB块。 可用地址范围如上图 机床MCP483面板地址表&#xff0c;其它类型的面板地址自己在828d简明调试手册里查看。 如何上载828d的plc程序&#xff1a; 1.通…

coze bot开发的最小实践

一、coze专业版开通 网站地址&#xff1a;扣子专业版-火山引擎 开通流程&#xff1a; 1."立即使用" 扣子专业版 1.点击【立即使用】2.登录账号(上一步已登录可跳过) 2.进行实名认证后&#xff0c;开启【扣子专业版】&#xff08;已认证可跳过&#xff09; 1. 前…

Mysql行转列的写法

一、何为行转列&#xff1f; 在搞清楚这一概率之前&#xff0c;不妨来认识一下我们mysql表二维表结构数据&#xff0c;例如学生成绩表格&#xff0c;属性有学生姓名&#xff0c;学生科目&#xff0c;成绩&#xff0c;表结构如下&#xff1a; CREATE TABLE test_9 (id int(11) …

Android map 获取值

Android Map 获取值的完整指南 在Android开发中&#xff0c;使用Map&#xff08;映射&#xff09;来存储和检索数据是非常常见的需求。Map是一种键值对集合&#xff0c;能够快速而高效地根据特定的键获取值。在这篇文章中&#xff0c;我们将深入探讨如何在Android应用中使用Ma…

Linux的zookeeper安装部署

1.zookeeper是一个分布式的,开放源码的分布式应用程序协调服务,是hadoop和HBASE的重要组件 2.下载zookeeper安装包zookeeper安装包https://archive.apache.org/dist/zookeeper/zookeeper-3.5.9/ 移动到Linux解压 解压到/export/server文件夹 命令: tar -xvf apache-zooke…

AI大模型:生产中的RAG,为何表现不尽如人意?

RAG&#xff08;Retrieval Augmented Generation,检索增强生成&#xff09;是一个将大规模语言模型(LLM)与来自外部知识源的检索相结合的框架,以改进问答能力的工程框架。虽然一切都看起来很美好&#xff0c;在实际应用中&#xff0c;RAG的状态确是“一看就会&#xff0c;一用就…

【Linux】嵌入式Linux系统的组成、u-boot编译

Linux—嵌入式Linux系统的组成、u-boot编译 前言一、嵌入式Linux系统的组成1.1 嵌入式Linux系统和PC完整的操作系统的对比如下&#xff1a;1.2 PC机—Windows系统启动流程&#xff08;PC机—Linux系统、嵌入式ARM—linux系统的启动流程类似&#xff09; 二、编译u-boot2.1 u-bo…

内核定时器API实现点灯

1.内核定时器 定时器是一个很常用的功能&#xff0c;需要周期性处理的工作都要用到定时器。 Linux 内核定时器 采用系统时钟来实现&#xff0c;并不是6ull里面的硬件定时器。 Linux 内核定时器使用很简单&#xff0c;只需要提供超时时间(相当于定时值)和定时处理函数即…

7万字Java后端面试题大全(附答案)——持续更新

目录 Java基础JDK/JRE/JVM三者的关系JDK常用的包 和 equals 的区别是什么&#xff1f;Java 中的几种基本数据类型了解么&#xff1f;什么是自动拆装箱&#xff1f;final 关键字中有什么作用&#xff1f;接口和抽象类有什么区别&#xff1f;String, StringBuffer 和 StringBuild…

构建流媒体管道:利用 Docker 部署 Nginx-RTMP 从 FFmpeg RTMP 推流到 HLS 播放的完整流程

最近要实现一个类似导播台的功能&#xff0c;于是我先用 FFmpeg 实现一个参考对照的 Demo&#xff0c;我将其整理为一篇文章&#xff0c;方便后续大家或者和自己参考&#xff01; 1、软件工具介绍 本次部署相关软件 / 工具如下&#xff1a; FFmpeg&#xff1a;全称是 Fast Fo…

与ZoomEye功能类似的搜索引擎还有哪些?(渗透课作业)

与ZoomEye功能类似的搜索引擎有&#xff1a; Shodan&#xff1a;被誉为“物联网的搜索引擎”&#xff0c;专注于扫描和索引连接到互联网的各种设备&#xff0c;如智能家居设备、工业控制系统、摄像头、数据库等。它提供全球互联网设备的可视化视图&#xff0c;帮助用户了解网络…

第21~22周Java主流框架入门-Spring 1SpringIoc容器与Bean管理

1.Spring IOC 与依赖注入课程笔记 课程简介 本节课介绍了 Spring 框架中的核心概念——IOC&#xff08;控制反转&#xff09;和 DI&#xff08;依赖注入&#xff09;。Spring 是 Java 生态中最重要的框架之一&#xff0c;几乎所有的 Java 项目开发都会使用它。理解 Spring 的…

RWKV-CHN模型部署教程

一、模型介绍 RWKV 语言模型&#xff08;用纯 100%RNN 达到 GPT 能力&#xff0c;甚至更强&#xff09;&#xff0c;该项目旨在通过为您自动化所有事情来消除使用大型语言模型的障碍。您需要的是一个只有几兆字节的轻量级可执行程序。此外&#xff0c;该项目还提供了一个接口兼…

python yolov8半自动标注

首先标注一部分图片&#xff0c;进行训练&#xff0c;生成模型&#xff0c;标注文件为xml方便后面统一做处理。 1、标注数据&#xff08;文件为xml, 转为txt用于训练&#xff0c;保留xml标签文件&#xff09; 2、模型训练&#xff08;训练配置、训练代码、&#xff09; 3、使用…

一个将.Geojson文件转成shapefile和kml文件的在线页面工具

最近需要读取.geojson格式的流域边界文件。在谷歌地球桌面版和globalMapper中均无法正常读取。下面我发现的一个在线的平台可以很好实现这一功能。 GeoJSON to SHP Converter Online - MyGeodata Cloud ❤️欢迎点赞收藏❤️