【C++】每日一题 50 Pow(x,n)

实现 pow(x, n) ,即计算 x 的整数 n 次幂函数(即,x^n )。

当需要计算x的n次幂时,可以使用递归或者迭代的方式来实现。

#include <iostream>double myPow(double x, int n) {if (n == 0) {return 1.0;} else if (n < 0) {return 1.0 / (x * myPow(x, -(n + 1)));} else {double half = myPow(x, n / 2);if (n % 2 == 0) {return half * half;} else {return x * half * half;}}
}int main() {double x = 2.0;int n = 10;std::cout << x << " raised to the power of " << n << " is: " << myPow(x, n) << std::endl;return 0;
}

在这个函数中,我们首先处理n为0和n为负数的情况,然后使用递归的方式计算x的n次幂。如果n为偶数,则将问题分解为计算x的n/2次幂,然后将结果相乘;如果n为奇数,则将问题分解为计算x的(n-1)/2次幂,然后将结果相乘,并额外乘以x。这样递归下去,直到n减小为0时返回1,从而完成了整数次幂的计算。

注意如果将这行代码

return 1.0 / (x * myPow(x, -(n + 1)));

替换为

 return 1.0/myPow(x,-n);


x =
1.00000
n =
-2147483648
时会溢出。
这个错误发生在对 -2147483648(即 INT_MIN)进行取反操作时。在 C++ 中,对 INT_MIN 进行取反会导致溢出,因为 INT_MIN 的绝对值大于 INT_MAX,无法表示为有符号整数的正值。
当 n 为 -2147483648 时,原始的代码中的 myPow(x, -n) 将会调用 myPow(x, 2147483648),这个值超出了 int 类型的范围,导致了溢出错误。
为了解决这个问题,要不需要将 n 强制转换为长整型 long long 类型,以避免溢出。
要不通过(x * myPow(x, -(n + 1)))处理使其不溢出

时间复杂度分析:

当 n 为正数时,我们可以通过递归将指数减半,因此时间复杂度为 O(logn),因为每次递归我们将指数减半。
当 n 为负数时,我们同样可以通过递归将指数加一减半,因此时间复杂度也为 O(logn)。

空间复杂度分析:

递归调用会使用栈空间,因此考虑递归的深度。由于每次递归将指数减半,所以递归的深度最多为 logn,因此空间复杂度为 O(logn)。
因此,经过修改后的 myPow 函数的时间复杂度为 O(logn),空间复杂度也为 O(logn)。这意味着无论是时间开销还是空间开销,随着指数的增长,都是以对数级别的速度增加的。

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

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

相关文章

Nginx日志管理与分析:从日志中挖掘价值

一、引言 Nginx作为一款高性能的HTTP和反向代理服务器&#xff0c;在Web服务中扮演着至关重要的角色。除了其强大的功能外&#xff0c;Nginx还提供了丰富的日志功能&#xff0c;可以帮助我们监控和分析Web服务的运行状态。然而&#xff0c;仅仅收集日志是远远不够的&#xff0…

c++ 里重解释转换之于引用 reinterpret_cast< long >

今天遇到了这一很新奇的写法。模糊中记得王老师也这么讲过。c 里四大转换。把数据重解释为原来数据的引用。虽然也可以直接定义对变量的引用。测试如下&#xff1a; 咱们从反汇编再了解下 c 编译器是怎么处理这种写法的&#xff1a; 谢谢

[合集] MySQL 8.x 系列文章清单

↑ 关注“少安事务所”公众号&#xff0c;欢迎⭐收藏&#xff0c;不错过精彩内容~ 从去年7月到现在&#xff0c;自 MySQL 发版模型变更后&#xff0c;已经发布了四个版本&#xff0c;意味着 MySQL 8.x 系列进入了长期支持状态。 当然&#xff0c;目前主要推荐的版本依旧是 MySQ…

【代码随想录训练营】【Day 35】【贪心-2】| Leetcode 122, 55, 45

【代码随想录训练营】【Day 35】【贪心-2】| Leetcode 122, 55, 45 需强化知识点 贪心&#xff1a;跳跃游戏 题目 122. 买卖股票的最佳时机 II 动态规划贪心&#xff1a;只要股票第二天涨了&#xff0c;前一天就买&#xff0c;第二就买 class Solution:def maxProfit(sel…

three.js官方案例webgl_loader_fbx.html学习

目录 1.1 添加库引入 1.2 添加必要的组件scene,camera,webrenderer等 1.3 模型加载 1.4 半球光 1.5 动画 1.6 换个自己的fbx模型 1.7 fbx模型和fbx动画关联 1.7 html脚本全部如下 1.8 fbx.js全部脚本如下 1.1 添加库引入 import * as THREE from three; import Stats …

AI芯片软件定义硬件架构

软件定义硬件架构 AI 应用正促使芯片制造商和 OEM 重新审视重新配置硬件的可能性。 摩尔定律放缓&#xff0c;软件应用复杂性和规模激增&#xff0c;x86架构CPU运行通用软件的传统方法已无法满足嵌入式和AI应用的高效需求。 在当前x86架构主导的环境中&#xff0c;软硬件间差…

在某云服务器上搭建公网kali linux2.0

前提&#xff1a; 可用的 CVM 实例 挂载一个系统盘之外的盘&#xff0c;安装完成后可卸载&#xff01; 创建实例&#xff0c;安装centos7系统&#xff01; 然后执行fdisk -l看磁盘的情况 在这里我将把镜像写入vdb这块数据盘 非 root 的情况下记得sudo执行以下命令 注意&…

使用 Elastic AI assistant for Observability 来分析日志

在今天的文章中&#xff0c;我们来参考之前的文章 “Elastic AI Assistant for Observability 和 Microsoft Azure OpenAI 入门” 来使用 Elastic AI assistant 分析日志。在本文章中&#xff0c;我们不使用 Azure clould。这样我们之间来进入主题&#xff0c;以免失去注意力。…

DDR、LPDDR和GDDR的区别

1、概况 以DDR开头的内存适用于服务器、云计算、网络、笔记本电脑、台式机和消费类应用&#xff0c;支持更宽的通道宽度、更高的密度和不同的形状尺寸。 以LPDDR开头的内存适合面向移动和汽车这些对规格和功耗非常敏感的领域&#xff0c;提供更窄的通道宽度和多种低功耗运行状态…

OSPF减少LSA更新量1

OSPF的LSA优化 一、汇总——优化骨干区域 (1)域间汇总ABR设备基于某个区域的1/2类LSA计算所得的最佳路由&#xff0c;共享给其他区域时&#xff0c;进行汇总传递。 [r2]ospf 1 [r2-ospf-1]area 1——明细路由所在区域&#xff0c;该ABR设备必须和明细路由在同一区域 [r2-ospf…

1738. 找出第 K 大的异或坐标值 Medium

给你一个二维矩阵 matrix 和一个整数 k &#xff0c;矩阵大小为 m x n 由非负整数组成。 矩阵中坐标 (a, b) 的 目标值 可以通过对所有元素 matrix[i][j] 执行异或运算得到&#xff0c;其中 i 和 j 满足 0 < i < a < m 且 0 < j < b < n&#xff08;下标从 …

数据集007:垃圾分类数据集(含数据集下载链接)

数据集简介 本数据拥有 训练集&#xff1a;43685张&#xff1b; 验证集&#xff1a;5363张&#xff1b; 测试集&#xff1a;5363张&#xff1b; 总类别数&#xff1a;158类。 部分代码&#xff1a; 定义数据集 class MyDataset(Dataset):def __init__(self, modetrain, …

25台es集群停止步骤

停止切割服务 使用Kibana Dev Tools 打开Kibana&#xff0c;导航到Dev Tools页面。在Console标签页中&#xff0c;执行以下命令来临时禁止分片的自动分配 Json 1PUT _cluster/settings 2{ 3 "transient": { 4 "cluster.routing.allocation.enable":…

win10/win11 优先调用大核的电源计划性能设置

前言 大小核&#xff0c;即Intel 12代开始的P-core&#xff08;性能核&#xff0c;一般叫大核&#xff09;和E-core&#xff08;能效核&#xff0c;一般叫小核&#xff09;异核架构。说下个人理解&#xff0c;就是英特尔为了增加cpu性能&#xff0c;但是又因为架构和功耗的限制…

网络通讯聊天工具的实现

学习网络与通信&#xff0c;实现聊天界面能够通过服务器进行私聊和群聊的功能。 1.服务器&#xff1a;ServeSocket 客户端先发送消息给服务器&#xff0c;服务器接受消息后再发送给客户端。 利用服务器随时监听。等待客户端的请求&#xff0c;一旦有请求便生产一个socket套接…

白杨SEO:为什么任何“创业”都要先找需求?以自己大学真实故事举例

创业&#xff0c;一般理解&#xff0c;狭义讲是指创办了个企业&#xff0c;广义是指创造一番事业。图片在公号白杨SEO上看。 我之所以把“创业”加了个双引号&#xff0c;除了上面狭义或者广义之外&#xff0c;我觉得像个体工作室、个人IP、自由职业甚至线下各类路边摊也可以算…

解决mybatis拦截器注入依赖后为null问题

需求是在mybatis拦截器中注入RedisUtils用来缓存一些信息。 拦截器 Component Intercepts({Signature(type Executor.class, method "update", args {MappedStatement.class, Object.class}) }) public class MybatisInterceptor implements Interceptor {priva…

模型实战(20)之 yolov8分类模型训练自己的数据集

yolov8分类模型训练自己的数据集 yolov8,一个实时快速的端到端的集检测、分割、分类、姿态识别于一体的视觉算法库/框架本文将给出yolov8 分类模型的数据集制作格式及训练流程 1. 环境搭建 关于虚拟环境的搭建真的是老生常谈了,给出一个简单的搭建流程吧#新建虚拟环境 conda …

软件系统开发标准流程文档(Word原件)

目的&#xff1a;规范系统开发流程&#xff0c;提高系统开发效率。 立项申请需求分析方案设计方案评审开发调整测试阶段系统培训试运行测试验收投入使用 所有文档过去进主页获取。 软件项目相关全套精华资料包获取方式①&#xff1a;点我获取 获取方式②&#xff1a;本文末个人…

DataFrame—数据汇总8

文章最前&#xff1a; 我是Octopus&#xff0c;这个名字来源于我的中文名--章鱼&#xff1b;我热爱编程、热爱算法、热爱开源。所有源码在我的个人github &#xff1b;这博客是记录我学习的点点滴滴&#xff0c;如果您对 Python、Java、AI、算法有兴趣&#xff0c;可以关注我的…