Day 28:2748. 美丽下标对的数目

2024-06-21 02:04
文章标签 day 28 2748 下标 数目 美丽

本文主要是介绍Day 28:2748. 美丽下标对的数目,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Leetcode 2748. 美丽下标对的数目

给你一个下标从 0 开始的整数数组 nums 。如果下标对 i、j 满足 0 ≤ i < j < nums.length ,如果 nums[i] 的 第一个数字 和 nums[j] 的 最后一个数字 互质 ,则认为 nums[i] 和 nums[j] 是一组 美丽下标对
返回 nums 中 美丽下标对 的总数目。
对于两个整数 x 和 y ,如果不存在大于 1 的整数可以整除它们,则认为 x 和 y 互质 。换而言之,如果 gcd(x, y) == 1 ,则认为 x 和 y 互质,其中 gcd(x, y) 是 x 和 y 的 最大公因数

image.png

判断两个数字是否互质,并不麻烦,从它们最小的值开始遍历到 2,看是否都能整除。当然,这肯定不是最优的算法。但在此题中,数字范围在 10 以内,因此计算也不是特别大。
再者,用两个数组分别保存数组值的第一个数字和最后一个数字,在判断互质时就不用每次都去计算第一个数字和最后一个数字了。

完整代码

class Solution {public int countBeautifulPairs(int[] nums) {int res = 0;int n = nums.length;int[] first = new int[n]; // 第一个数字int[] last = new int[n]; // 最后一个数字for (int i = 0; i < n; i++) {last[i] = nums[i] % 10;first[i] = getFirst(nums[i]);}for (int i = 0; i < n; i++) {for (int j = i + 1; j < n; j++) {if (gcd(first[i], last[j]) ==  1) res++;}}return res;}public int getFirst(int num) {while (num >= 10) num /= 10;return num;}public int gcd(int a, int b) {for (int i = Math.min(a, b); i > 1; i--) {if ((a % i == 0) && (b % i == 0)) return i;}return 1;}
}

这篇关于Day 28:2748. 美丽下标对的数目的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1079903

相关文章

随想录 Day 69 并查集 107. 寻找存在的路径

随想录 Day 69 并查集 107. 寻找存在的路径 理论基础 int n = 1005; // n根据题目中节点数量而定,一般比节点数量大一点就好vector<int> father = vector<int> (n, 0); // C++里的一种数组结构// 并查集初始化void init() {for (int i = 0; i < n; ++i) {father[i] = i;}

Codeforces April Fools Day Contest 2014(附官方题解)

Codeforces2014年愚人节的坑题。。。但还是感觉挺好玩的。。。 A. The Great Game time limit per test 1 second memory limit per test 256 megabytes input standard input output standard output Two teams mee

Codeforces April Fools Day Contest 2013

2013年愚人节的坑题。。。 A. Mysterious strings time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standard output Input The input contains a sin

随想录 Day 66 101. 孤岛的总面积 102. 沉没孤岛 103. 水流问题

随想录 Day 66 101. 孤岛的总面积 102. 沉没孤岛 103. 水流问题 101. 孤岛的总面积 101. 孤岛的总面积 时间限制:1.000S 空间限制:256MB 题目描述 给定一个由 1(陆地)和 0(水)组成的矩阵,岛屿指的是由水平或垂直方向上相邻的陆地单元格组成的区域,且完全被水域单元格包围。孤岛是那些位于矩阵内部、所有单元格都不接触边缘的岛屿。 现在你需要计算所有孤

Day 31:100334. 包含所有1的最小矩形面积Ⅰ

Leetcode 100334. 包含所有1的最小矩形面积Ⅰ 给你一个二维 **二进制 **数组 grid。请你找出一个边在水平方向和竖直方向上、面积 最小 的矩形,并且满足 grid 中所有的 1 都在矩形的内部。 返回这个矩形可能的 **最小 **面积。 确定首次出现 1 的第一行 top,最后一次出现 1 的最后一列 r,最后一次出现 1 的最后一行 bottom,首次出现的第

查询每名学生的学号、选修课程数目、总成绩、并将查询结果存放到生成的’学生选课统计表‘中

--查询每名学生的学号、选修课程数目、总成绩、并将查询结果存放到生成的’学生选课统计表‘中use teachinggoif exists (select * from sys.objects where name='学生选课统计表')drop table 学生选课统计表select studentno,COUNT(*) as '选修课程数目',sum(final) as '总成绩' i

Leetcode3185. 构成整天的下标对数目 II

Every day a Leetcode 题目来源:3185. 构成整天的下标对数目 II 解法1:哈希 本质思路类同经典的“两数之和”。枚举右,用哈希表维护左。 枚举 j,并维护 cnt[x] 表示所有满足 i < j 的下标 i 中,有几个 hours[i] 模 24 等于 x。设 y = nums[j] % 24,那么答案就是 sum(cnt[(24 - y) % 24])。 注意

[Day 19] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

區塊鏈的數據透明性 區塊鏈技術作為一種分布式賬本技術,因其去中心化、不可篡改和高度透明的特性,已經在各行各業中得到了廣泛應用。在本文中,我們將深入探討區塊鏈的數據透明性,包括其原理、實現方法及相關代碼示例,並詳細解釋每段代碼的作用。 1. 區塊鏈數據透明性的原理 區塊鏈技術的核心是去中心化的分布式賬本,這意味著每個區塊中的數據都是公開的,並且可以由任何節點查看和驗證。這種透明性主要來源於以下

动手学深度学习(Pytorch版)代码实践 -卷积神经网络-28批量规范化

28批量规范化 """可持续加速深层网络的收敛速度"""import torchfrom torch import nnimport liliPytorch as lpimport matplotlib.pyplot as pltdef batch_norm(X, gamma, beta, moving_mean, moving_var, eps, momentum):"""实现一个具有

CentOS7下安装MySQL8.0.28

目录 一、下载二、解压三、按顺序安装rpm包四、启动五、找到初始密码六、修改密码并授权七、开启防火墙,允许外网访问 一、下载 下载地址:https://dev.mysql.com/downloads/mysql/8.0.html 二、解压 tar xvf mysql-8.0.28-1.el7.x86_64.rpm-bundle.tar 三、按顺序安装rpm包 rp