当前位置: 首页 > article >正文

2748. 美丽下标对的数目(Beautiful Pairs)

2748. 美丽下标对的数目(Beautiful Pairs)

题目分析

给定一个整数数组 nums,我们需要找出其中符合条件的“美丽下标对”。美丽下标对是指,数组中的某一对数字 nums[i]nums[j](其中 0 ≤ i < j < nums.length)满足以下条件:

  • nums[i] 的第一个数字(即 nums[i] 的最左边的数字)
  • nums[j] 的最后一个数字(即 nums[j] 的最右边的数字)

这两个数字互质,即 gcd(nums[i]的第一个数字, nums[j]的最后一个数字) == 1。如果满足这个条件,则认为这对下标是“美丽下标对”。

题解思路

暴力解法

在这个问题中,最简单的做法是使用双重循环来遍历所有可能的数字对,然后判断它们的第一个数字和最后一个数字是否互质。

步骤分析:

  1. 提取数字的第一个数字和最后一个数字:

    • 对于 nums[i],我们可以通过字符串操作或者数学运算得到其第一个数字。
    • 对于 nums[j],我们可以直接用 nums[j] % 10 来获取最后一个数字。
  2. 计算 gcd

    • 使用 Python 中的 math.gcd 函数来计算两个数字的最大公约数。
    • 如果 gcd 的结果是 1,则认为这对数字互质。
  3. 统计美丽下标对:

    • 对于每一对 (i, j),如果它们满足互质的条件,增加计数器。

代码实现

Python 代码
from math import gcd

class Solution:
    def countBeautifulPairs(self, nums: List[int]) -> int:
        n, res = len(nums), 0
        for i in range(n):
            for j in range(i + 1, n):
                # 提取第一个数字和最后一个数字
                a = int(str(nums[i])[0])  # nums[i] 的第一个数字
                b = nums[j] % 10  # nums[j] 的最后一个数字
                # 判断是否互质
                if gcd(a, b) == 1:
                    res += 1
        return res
C++ 代码
#include <vector>
#include <numeric>  // gcd
using namespace std;

class Solution {
public:
    int countBeautifulPairs(vector<int>& nums) {
        int res = 0;
        for (int i = 0; i < nums.size() - 1; i++) {
            for (int j = i + 1; j < nums.size(); j++) {
                int a = nums[i], b = nums[j] % 10;
                // 提取 nums[i] 的第一个数字
                while (a >= 10) {
                    a /= 10;
                }
                // 判断是否互质
                if (gcd(a, b) == 1) {
                    res++;
                }
            }
        }
        return res;
    }
};

代码优化与分析

  1. 暴力解法的时间复杂度:

    • 外层循环遍历所有的 i,内层循环遍历所有的 j,因此总共有 O(n^2) 次操作。对于 n <= 100(题目限制),这样的时间复杂度是可以接受的。
    • 提取数字的第一个数字和最后一个数字的操作是常数时间 O(1),所以整体时间复杂度为 O(n^2)
  2. 优化点:

    • 暴力解法已经是最直观的解决方案,但由于题目中数组的长度最大为 100,在这个范围内时间复杂度 O(n^2) 是能够承受的。因此,当前的暴力解法对于本题来说足够高效。
    • 如果数据规模更大,可能需要考虑其他优化方法,比如使用哈希表等数据结构来减少重复计算,但在这里并不需要。

示例解析

示例 1

输入:

nums = [2, 5, 1, 4]

步骤:

  • (nums[0] = 2, nums[1] = 5)gcd(2, 5) = 1,符合条件。
  • (nums[0] = 2, nums[2] = 1)gcd(2, 1) = 1,符合条件。
  • (nums[0] = 2, nums[3] = 4)gcd(2, 4) = 2,不符合条件。
  • (nums[1] = 5, nums[2] = 1)gcd(5, 1) = 1,符合条件。
  • (nums[1] = 5, nums[3] = 4)gcd(5, 4) = 1,符合条件。
  • (nums[2] = 1, nums[3] = 4)gcd(1, 4) = 1,符合条件。

输出:

5

示例 2

输入:

nums = [11, 21, 12]

步骤:

  • (nums[0] = 11, nums[1] = 21)gcd(1, 1) = 1,符合条件。
  • (nums[0] = 11, nums[2] = 12)gcd(1, 2) = 1,符合条件。
  • (nums[1] = 21, nums[2] = 12)gcd(2, 2) = 2,不符合条件。

输出:

2

结论

通过暴力解法,我们可以解决这类问题,尽管它的时间复杂度为 O(n^2),但在本题中,数据规模较小,暴力解法是完全可以接受的。此外,我们也展示了如何通过提取数字的第一个数字和最后一个数字,利用 gcd 判断是否满足美丽下标对的条件。


http://www.kler.cn/a/523937.html

相关文章:

  • 【单细胞第二节:单细胞示例数据分析-GSE218208】
  • Android车机DIY开发之学习篇(七)NDK交叉工具构建
  • 16届蓝桥杯寒假刷题营】第2期DAY5IOI赛
  • 支持selenium的chrome driver更新到132.0.6834.110
  • Linux 4.19内核中的内存管理:x86_64架构下的实现与源码解析
  • 电路研究9.2.3——合宙Air780EP中FTP——FTPGET 命令使用方法研究
  • 【Python】 使用pygame库实现新年烟花
  • 支持selenium的chrome driver更新到132.0.6834.110
  • 彻底理解Flink的多种部署方式
  • 人工智能丨基于机器学习的视觉 CV 处理技术
  • 开发第一个安卓页面
  • 长尾关键词优化对提升SEO和网站访客流量的实用影响与策略
  • C语言深入解析 printf的底层源码实现
  • 【前端】Hexo 部署指南_hexo-deploy-git·GitHub Actions·Git Hooks
  • 接口 V2 完善:分布式环境下的 WebSocket 实现与 Token 校验
  • docker desktop使用ollama在GPU上运行deepseek r1大模型
  • ACL-2024 | 具身智能空间理解能力几何?EmbSpatial-Bench:视觉语言大模型在具身任务中空间理解水平测试基准
  • 如何获取svg图标中的路径 (漫反射图标效果实现)
  • 算法随笔_29:最大宽度坡_方法3
  • 澳洲硕士毕业论文写作中如何把握主题
  • 笔记本跑大模型尝试
  • 奖励模型:解析大语言模型的关键工具
  • 作業系統:設計與實現-母本
  • 密码学的数学基础1-整数 素数 和 RSA加密
  • vim交换文件的作用
  • 关于2024年