当前位置:首页 > PHP

php实现丑数

2026-02-16 01:21:22PHP

丑数定义

丑数是指只包含质因数2、3或5的正整数。1通常被视为第一个丑数。例如,前10个丑数为1, 2, 3, 4, 5, 6, 8, 9, 10, 12。

php实现丑数

判断丑数的方法

要判断一个数是否为丑数,可以不断将其除以2、3、5,直到无法整除为止。如果最终结果为1,则该数是丑数;否则不是。

php实现丑数

function isUgly($num) {
    if ($num <= 0) {
        return false;
    }
    $factors = [2, 3, 5];
    foreach ($factors as $factor) {
        while ($num % $factor == 0) {
            $num = $num / $factor;
        }
    }
    return $num == 1;
}

生成第n个丑数

要生成第n个丑数,可以使用动态规划的方法。维护三个指针分别对应乘以2、3、5的最小丑数,每次选择最小的乘积作为下一个丑数。

function nthUglyNumber($n) {
    $uglyNumbers = array_fill(0, $n, 0);
    $uglyNumbers[0] = 1;
    $i2 = $i3 = $i5 = 0;
    $nextMultipleOf2 = 2;
    $nextMultipleOf3 = 3;
    $nextMultipleOf5 = 5;

    for ($i = 1; $i < $n; $i++) {
        $nextUglyNumber = min($nextMultipleOf2, $nextMultipleOf3, $nextMultipleOf5);
        $uglyNumbers[$i] = $nextUglyNumber;

        if ($nextUglyNumber == $nextMultipleOf2) {
            $i2++;
            $nextMultipleOf2 = $uglyNumbers[$i2] * 2;
        }
        if ($nextUglyNumber == $nextMultipleOf3) {
            $i3++;
            $nextMultipleOf3 = $uglyNumbers[$i3] * 3;
        }
        if ($nextUglyNumber == $nextMultipleOf5) {
            $i5++;
            $nextMultipleOf5 = $uglyNumbers[$i5] * 5;
        }
    }
    return $uglyNumbers[$n - 1];
}

示例用法

// 判断一个数是否为丑数
var_dump(isUgly(6)); // 输出: bool(true)
var_dump(isUgly(14)); // 输出: bool(false)

// 获取第n个丑数
echo nthUglyNumber(10); // 输出: 12

注意事项

  • 输入为负数或0时,直接返回false。
  • 动态规划方法的时间复杂度为O(n),空间复杂度为O(n)。

标签: php
分享给朋友:

相关文章

git php实现

git php实现

Git 与 PHP 的集成实现 使用 PHP 执行 Git 命令 通过 PHP 的 exec()、shell_exec() 或 passthru() 函数可以直接调用 Git 命令,适用于服务器端操作…

php实现注册登录

php实现注册登录

PHP 注册功能实现 创建数据库表(以 MySQL 为例) CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, usern…

php 实现面包屑导航

php 实现面包屑导航

实现面包屑导航的方法 面包屑导航(Breadcrumb Navigation)是一种常见的网站导航方式,用于显示用户当前页面的路径。以下是几种在 PHP 中实现面包屑导航的方法。 基于 URL 路径…

php https实现

php https实现

PHP 中实现 HTTPS 的方法 在 PHP 中实现 HTTPS 主要通过配置服务器和编写代码来确保通信的安全性。以下是几种常见的方法: 配置服务器支持 HTTPS 确保服务器已安装 SSL/T…

php session实现购物车

php session实现购物车

PHP Session 实现购物车 初始化 Session 确保在使用 Session 前调用 session_start() 函数。通常放在 PHP 文件的最顶部。 <?php sessio…

php下载文件实现

php下载文件实现

PHP 下载文件实现方法 使用 header() 函数强制下载 设置合适的 HTTP 头信息,强制浏览器下载文件而非直接打开。 $file_path = '/path/to/file.pdf'; $…