博客
关于我
leetcode题解50-Pow(x,n)
阅读量:791 次
发布时间:2023-01-31

本文共 1740 字,大约阅读时间需要 5 分钟。

要实现pow(x, n)函数,我们需要考虑很多特殊情况和优化点。

特殊情况处理

  • n为0:不管x是什么,结果都是1。
  • n为正偶数:结果为正数。
  • x为0:当n>0,结果为0。
  • 代码逻辑

    public class Solution {    public double myPow(double x, int n) {        // 处理n为0的情况        if (n == 0)            return 1.0;        // 处理x为-1的情况        if (Math.Abs(x) == 1.0) {            if ((x > 0) && (n % 2 == 0))                return 1.0;            if (x < 0 && (n % 2 != 0))                return -1.0;            return 1.0;        }        // 处理x为1的情况        if (Math.Abs(x) == 1.0) {            return x == 1.0 ? 1.0 : -1.0;        }        // 处理微小的浮点数误差        if ((x > 1.0 && x < 2.0) || (x < -1.0 && x > -2.0)) {            // 特殊处理接近于1的值            if ((n > 0 && x == 1.0) || (n < 0 && x == -1.0)) {                return 1.0;            }        }        // 处理n为正数的情况        if (n > 0) {            double result = x;            int m = n;            // 逐步计算,避免数值过大导致溢出的问题            do {                result *= x;                // 检查结果是否趋近于0                if (result < 1.0 / 1024.0)                    return 0.0;            } while (m-- > 0);            return result;        } else {            // 处理n为负数的情况            int m = -n;            do {                try {                    result *= result;                    // 检查是否结果趋近于0                    if (result < 1.0 / 1024.0)                        return 0.0;                } catch (OverflowException) {                    // 检查结果是否会溢出                    if (result > 1.7976931348623157e+308)                        return 0.0;                }            } while (m-- > 0);            // 取倒数            return 1.0 / result;        }    }}

    优化点

    • 数字处理:当计算结果趋向于0时,提前终止循环。
    • 避免溢出:使用双精度数并检查计算结果是否接近最大值。
    • 特殊值处理:快速处理x为1和-1的情况,以及n为0的情况,确保代码高效运行。
    • 减少循环次数:通过对数运算或者位处理,减少循环次数,提高性能。

    转载地址:http://pegyk.baihongyu.com/

    你可能感兴趣的文章
    15个Python数据处理技巧(非常详细)零基础入门到精通,收藏这一篇就够了
    查看>>
    2024年全国程序员平均薪资排名:同样是程序员,为什么差这么多?零基础到精通,收藏这篇就够了
    查看>>
    0基础成功转行网络安全工程师,年薪30W+,经验总结都在这(建议收藏)
    查看>>
    10个程序员可以接私活的平台
    查看>>
    10个运维拿来就用的 Shell 脚本,用了才知道有多爽,零基础入门到精通,收藏这一篇就够了
    查看>>
    10款最佳免费WiFi黑客工具(附传送门)零基础入门到精通,收藏这一篇就够了
    查看>>
    15个备受欢迎的嵌入式GUI库,从零基础到精通,收藏这篇就够了!
    查看>>
    15个程序员常逛的宝藏网站!!从零基础到精通,收藏这篇就够了!
    查看>>
    2023最新版Node.js下载安装及环境配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    2024 年需要了解的顶级大数据工具(非常详细)零基础入门到精通,收藏这一篇就够了
    查看>>
    2024 最新 Kali Linux 定制化魔改,完整版,添加常见60渗透工具,零基础入门到精通,收藏这篇就够了
    查看>>
    2024大模型行业应用十大典范案例集(非常详细)零基础入门到精通,收藏这一篇就够了
    查看>>
    2024年全球顶尖杀毒软件,从零基础到精通,收藏这篇就够了!
    查看>>
    2024年度“金智奖”揭晓:绿盟科技获双项大奖,创新驱动网络安全新高度。从零基础到精通,收藏这篇就够了!
    查看>>
    2024年最流行的十大开源渗透测试工具
    查看>>
    2024年网络安全八大前沿趋势,零基础入门到精通,收藏这篇就够了
    查看>>
    2024年薪酬最高的五个网络安全职位,零基础入门到精通,收藏这一篇就够
    查看>>
    2024年非科班的人合适转行做程序员吗?
    查看>>
    2024数字安全创新性案例报告,从零基础到精通,收藏这篇就够了!
    查看>>
    2024最新最全CTF入门指南(非常详细)零基础入门到精通,收藏这一篇就够了
    查看>>