【力扣:新动计划,编程入门 —— 题解 ②】

news2025/1/24 10:51:07

—— 25.1.23

1512. 好数对的数目

给你一个整数数组 nums 。

如果一组数字 (i,j) 满足 nums[i] == nums[j] 且 i < j ,就可以认为这是一组 好数对 。

返回好数对的数目。

示例 1:

输入:nums = [1,2,3,1,1,3]
输出:4
解释:有 4 组好数对,分别是 (0,3), (0,4), (3,4), (2,5) ,下标从 0 开始

示例 2:

输入:nums = [1,1,1,1]
输出:6
解释:数组中的每组数字都是好数对

示例 3:

输入:nums = [1,2,3]
输出:0

方法一 暴力遍历

思路与算法

双重循环进行遍历,判断nums[i] == nums[j]时,计数变量sum+1,当双重循环进行遍历完成后,返回计数变量sum

Python实现

class Solution:
    def numIdenticalPairs(self, nums: List[int]) -> int:
        sum = 0
        for i in range(len(nums)):
            for j in range(i + 1,len(nums)):
                if nums[i] == nums[j]:
                    sum += 1
        return sum
        


Java实现 

class Solution {
    public int numIdenticalPairs(int[] nums) {
        int i = 0;
        int j = 0;
        int num = 0;
        for(i = 0; i < nums.length; i++){
            for(j = i + 1; j < nums.length; j++){
                if(nums[i] == nums[j]){
                    num += 1;
                } 
            }
        }
        return num;
    }
}


方法二 字典 + 哈希表

思路与算法

如果一个元素在数组中出现 k 次,则选择两个元素组成好数对的方案数是: k × (k−1) / 2因此该元素对应的好数对的数目是: k × (k−1) / 2

因此,只要得到每个元素在数组中的出现次数,分别计算每个元素对应的好数对的数目,即可得到数组中的好数对的数目。

Python实现

values()返回一个视图对象,该对象包含了字典中所有的值。借助这个视图对象,你能够遍历字典里的所有值,并且它会动态地反映出字典的变化。

keys()返回一个视图对象,该视图对象包含了字典中所有的键

class Solution:
    def numIdenticalPairs(self, nums: List[int]) -> int:
        res = {}
        sum = 0
        for i in nums:
            if i not in res.keys():
                res[i] = 1
            else:
                res[i] += 1
        for j in res.values():
            if j != 1:
                sum += j * (j-1) // 2
        return sum
            

Java实现 

getOrDefault():Map 接口定义了 getOrDefault 方法,该方法的作用是从 Map 中获取指定键对应的值。若该键存在于 Map 中,就返回其对应的值;若键不存在,则返回预先指定的默认值。这一方法能避免在使用 get 方法时手动检查键是否存在并提供默认值的繁琐操作。

entrySet():用于返回一个包含 Map 中所有键值对(即 Map.Entry 对象)的 Set 集合视图。Map.Entry 是 Map 接口的一个内部接口,它代表了 Map 中的一个键值对,其中包含了键和对应的值。

getValue() :getValue() 是 Map.Entry 接口所定义的方法,其作用是获取当前键值对中的值。

class Solution {
    public int numIdenticalPairs(int[] nums) {
        HashMap<Integer, Integer> res = new HashMap<>();
        for(int num: nums){
            res.put(num, res.getOrDefault(num, 0) + 1);
        }
        Set<Map.Entry<Integer, Integer>> entries = res.entrySet();
        int sum = 0;
        for (Map.Entry<Integer, Integer> entry : entries) {
            int count = entry.getValue();
            sum += count * (count - 1) / 2;
        }
        return sum;
    }
}


1534. 统计好三元组

给你一个整数数组 arr ,以及 ab 、c 三个整数。请你统计其中好三元组的数量。

如果三元组 (arr[i], arr[j], arr[k]) 满足下列全部条件,则认为它是一个 好三元组 。

  • 0 <= i < j < k < arr.length
  • |arr[i] - arr[j]| <= a
  • |arr[j] - arr[k]| <= b
  • |arr[i] - arr[k]| <= c

其中 |x| 表示 x 的绝对值。

返回 好三元组的数量 。

示例 1:

输入:arr = [3,0,1,1,9,7], a = 7, b = 2, c = 3
输出:4
解释:一共有 4 个好三元组:[(3,0,1), (3,0,1), (3,1,1), (0,1,1)] 。

示例 2:

输入:arr = [1,1,2,2,3], a = 0, b = 0, c = 1
输出:0
解释:不存在满足所有条件的三元组。 

方法一 暴力遍历 

思路与算法

Python实现

abs(): 是一个内置函数,用于返回一个数的绝对值。绝对值指的是一个数在数轴上所对应点到原点的距离,所以绝对值一定是非负的。

class Solution:
    def countGoodTriplets(self, arr: List[int], a: int, b: int, c: int) -> int:
        res = 0
        for i in range(len(arr)):
            for j in range(i + 1, len(arr)):
                for k in range(j + 1, len(arr)):
                    if abs(arr[i] - arr[j]) <= a and abs(arr[j] - arr[k]) <= b and abs(arr[i] - arr[k]) <= c:
                        res = res + 1
        return res
        


Java实现

Math.abs(): 是 Java 中的一个静态方法,它属于 java.lang.Math 类,主要用于返回一个数的绝对值。绝对值是指一个数在数轴上所对应点到原点的距离,所以其结果总是非负的。

class Solution {
    public int countGoodTriplets(int[] arr, int a, int b, int c) {
        int res = 0;
        for(int i = 0; i < arr.length; i++){
            for(int j = i + 1; j < arr.length; j++){
                for(int k = j + 1; k < arr.length; k++){
                    if(Math.abs(arr[i] - arr[j]) <= a && Math.abs(arr[j] - arr[k]) <= b && Math.abs(arr[i] - arr[k]) <= c){
                        res += 1;
                    }
                }
            }
        }
        return res;
    }
}


709. 转换成小写字母

示例 1:

输入:s = "Hello"
输出:"hello"

示例 2:

输入:s = "here"
输出:"here"

示例 3:

输入:s = "LOVELY"
输出:"lovely"

提示:

  • 1 <= s.length <= 100
  • s 由 ASCII 字符集中的可打印字符组成

方法一 遍历判断处理

思路与算法

遍历字符串,判断每个字符是否为大写字母,如果是的话就转换为小写字母(ASCI码值加32),本身是小写字母就不用转换,最后将各个字符组装成字符串输出。

Python实现

ord():函数用于返回一个字符的 Unicode 码点(整数表示)。Unicode 是一种国际编码标准,它为世界上几乎所有的字符都分配了一个唯一的数字编号,这个编号就是码点

chr():函数与 ord() 函数相反,它接受一个整数(Unicode 码点)作为参数,并返回对应的字符

append():是列表(list)对象的一个方法,用于在列表的末尾添加一个新的元素。该操作会直接修改原列表,而不会返回一个新的列表。

join():是字符串对象的一个方法,用于将一个可迭代对象(如列表、元组等)中的元素以指定的字符串为分隔符连接成一个新的字符串

class Solution:
    def toLowerCase(self, str: str) -> str:
        res = []
        for i in str:
            if 65 <= ord(i) <= 90:
                res.append(chr(ord(i) + 32))
            else:
                res.append(i)
        return "".join(res)

Java实现

charAt():是 String 类的一个实例方法,其作用是返回字符串中指定索引位置的字符。索引从 0 开始计数,即第一个字符的索引为 0,第二个字符的索引为 1,依此类推。

(char)():(char)() 属于强制类型转换操作。它可以把其他基本数据类型(像 intbyteshort 等)转换为 char 类型。

append():append() 方法可以将各种类型的数据添加到 StringBuilder 或 StringBuffer 对象的末尾

toString():该方法的作用是返回对象的字符串表示形式。许多类会重写这个方法,以提供更有意义的字符串表示。

class Solution {
    public String toLowerCase(String s) {
        StringBuilder str = new StringBuilder();
        for(int i = 0; i < s.length(); i++){
            char ch = s.charAt(i);
            if(ch >= 65 && ch <= 90){
                ch = (char)(ch+32);
            }
            str.append(ch);
        }
        return str.toString();
    }
}


方法二 转小写API

思路与算法

使用语言自带的大写字母转小写字母的 API

Python实现

lower():把字符串中的所有大写字母转换为小写字母,而字符串中的其他字符(如小写字母、数字、标点符号等)保持不变。该方法不会修改原字符串,而是返回一个新的字符串。

class Solution:
    def toLowerCase(self, s: str) -> str:
        return s.lower()


Java实现

toLowerCase():其功能是把字符串中的所有大写字母转换为小写字母,同样不会修改原字符串,而是返回一个新的字符串。

class Solution {
    public String toLowerCase(String s) {
        return s.toLowerCase();
    }
}

 

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

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

相关文章

如何在data.table中处理缺失值

&#x1f4ca;&#x1f4bb;【R语言进阶】轻松搞定缺失值&#xff0c;让数据清洗更高效&#xff01; &#x1f44b; 大家好呀&#xff01;今天我要和大家分享一个超实用的R语言技巧——如何在data.table中处理缺失值&#xff0c;并且提供了一个自定义函数calculate_missing_va…

《RWA全球产业白皮书》发布:向凌云教授解析全球经济转型与RWA的未来

2025年1月16日&#xff0c;旅美经济学家、全球新兴产业金融专家向凌云教授在美国发布了引人注目的《RWA全球产业白皮书》。该白皮书通过深入分析全球产业结构变化&#xff0c;尤其强调了“真实世界资产”&#xff08;Real-World Assets&#xff0c;简称RWA&#xff09;在当前及…

TOGAF之架构标准规范-信息系统架构 | 数据架构

TOGAF是工业级的企业架构标准规范&#xff0c;信息系统架构阶段是由数据架构阶段以及应用架构阶段构成&#xff0c;本文主要描述信息系统架构阶段中的数据架构阶段。 如上所示&#xff0c;信息系统架构&#xff08;Information Systems Architectures&#xff09;在TOGAF标准规…

安宝特方案 | AR在供应链管理中的应用:提升效率与透明度

随着全球化的不断深入和市场需求的快速变化&#xff0c;企业对供应链管理的要求也日益提高。如何在复杂的供应链环境中提升效率、降低成本&#xff0c;并确保信息的透明度&#xff0c;成为了各大行业亟待解决的问题。而增强现实&#xff08;AR&#xff09;技术&#xff0c;特别…

C语言数组详解:从基础到进阶的全面解析

在C语言中&#xff0c;数组是一种基本的数据结构&#xff0c;用于存储多个相同类型的数据。数组的引入使得C语言能够高效地存储和操作大量数据。在任何一个C语言程序中&#xff0c;数组都发挥着极其重要的作用。无论是在算法实现、数据存储、还是在复杂程序的设计中&#xff0c…

阴沟翻船题——Longest Substring Without Repeating Characters

一、事件概述 今天接到一个面试&#xff0c;让线上做题。面试官出了个leetcode的题。题目如图所示&#xff1a; 我没有刷过leetcode&#xff0c;上学时候我们做的hdu-acm和codeforces。咋一接到题目&#xff0c;看到是个字符串题&#xff0c;并且找最长字串&#xff0c;第一反…

ssm基于HTML5的红酒信息分享系统

SSM基于HTML5的红酒信息分享系统是一个专注于红酒领域的综合性信息平台&#xff0c;旨在为红酒爱好者、从业者以及普通消费者提供一个便捷的交流与获取红酒相关信息的空间。 一、系统背景与意义 随着人们生活水平的提高和消费观念的转变&#xff0c;红酒作为一种高雅的饮品&a…

【FFmpeg】FLV 格式分析 ③ ( Tag Body 数据块体结构 - Vedio Data 视频数据 )

文章目录 一、Tag Body 数据块体结构 - Video Data 视频数据1、Vedio Data 视频数据 类型标识2、Vedio Data 视频数据 结构分析3、Composition Time Offset 字段涉及的时间计算4、AVC Packet Type 字段说明① AVC Sequence Header 类型② AVC NALU 类型③ AVC End of Sequence …

解决docker: ‘buildx‘ is not a docker command.

简介 buildx 是 Docker 官方提供的一个构建工具&#xff0c;它可以帮助用户快速、高效地构建 Docker 镜像&#xff0c;并支持多种平台的构建。使用 buildx&#xff0c;用户可以在单个命令中构建多种架构的镜像&#xff0c;例如 x86 和 ARM 架构&#xff0c;而无需手动操作多个…

Centos类型服务器等保测评整/etc/pam.d/system-auth

修改服务器配置文件/etc/pam.d/system-auth&#xff0c;但是&#xff0c;把一下配置放在password的配置第一行才会生效 执行命令&#xff1a;配置口令要求&#xff1a;大小写字母、数字、特殊字符组合、至少8位&#xff0c;包括强制设置root口令&#xff01; sed -i 14a pas…

精准捕捉,智能训练:数据手套在机器人灵巧手领域的应用探索

数据手套是一种内置多个高精度传感器&#xff0c;能够精准捕捉手部动作数据&#xff0c;并将其转化为数字信号的高科技穿戴设备。 MHand pro动捕数据手套其内置16个高精度传感器&#xff0c;能敏锐感知手指的弯曲、伸展等动作。这些传感器通过复杂的算法&#xff0c;将手部动作…

FPGA实现任意角度视频旋转(二)视频90度/270度无裁剪旋转

本文主要介绍如何基于FPGA实现视频的90度/270度无裁剪旋转&#xff0c;关于视频180度实时旋转&#xff0c;请见本专栏前面的文章&#xff0c;旋转效果示意图如下&#xff1a; 为了实时对比旋转效果&#xff0c;采用分屏显示进行处理&#xff0c;左边代表旋转前的视频在屏幕中…

PHP如何封装项目框架达到高可用、高性能、高并发

很多初创公司为了快速上线业务&#xff0c;开发时间由本来的6个月压缩到3个月甚至2个月。开发人员只能根据时间及业务需求去git上找现有的项目二次开发或者是一个空框架根据业务一点一点的去做&#xff0c;上述两种方案虽然也可以上线但是对于业务本身存在的问题也是很大的&…

Java设计模式—观察者模式

观察者模式 目录 观察者模式1、什么是观察者模式&#xff1f;2、观察者模式优缺点及注意事项&#xff1f;3、观察者模式实现&#xff1f;4、手写线程安全的观察者模式&#xff1f; 1、什么是观察者模式&#xff1f; - 实例&#xff1a;现实生活中很多事物都是依赖存在的&#x…

DAY9,递归实现计算 :1 + 1/3 - 1/5 + 1/7 - 1/9 + .... 1/n 的值

题目 用递归实现计算 :1 1/3 - 1/5 1/7 - 1/9 .... 1/n 的值&#xff0c;n通过键盘输入 思路 递进阶段&#xff1a;n、...... 、9、7、5、3、1 函数出口&#xff1a;递进到1 开始返回&#xff1b;函数返回值视为“总和” 回归阶段&#xff1a;对当前n取倒数&#xff1b;“总…

【数据结构进阶】红黑树超详解 + 实现(附源码)

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;数据结构 目录 前言 一、红黑树介绍 二、红黑树原理详解 三、红黑树的实现 1. 节点定义 2. 红黑树类型定义及接口声明 3. 红黑树的插入&#xff08;重点&a…

微服务与docker

准备工作 在课前资料中给大家提供了黑马商城项目的资料,我们需要先导入这个单体项目。不过需要注意的是,本篇及后续的微服务学习都是基于Centos7系统下的Docker部署,因此你必须做好一些准备: Centos7的环境及一个好用的SSH客户端装好Docker会使用Docker如果是学习过上面Doc…

H3C-无线WLAN配置案例(二层隧道转发)

目录 1.无线wlan产生背景:2.网络拓扑:3.网络简述:4.网络配置:4.1 网络基础配置4.2 无线wlan二层隧道转发配置4.3 无线wlan验证: 1.无线wlan产生背景: 无线WLAN&#xff08;无线局域网&#xff09;的产生背景主要源于以下几个方面的需求和技术发展&#xff1a;移动性和便捷性需…

Unreal Engine 5 C++ Advanced Action RPG 十一章笔记

第十一章 In Game Widgets 本章节就是做UI2-Template Button Widget 这章节创建不同的UI 结束UI胜利UI暂停菜单主菜单加载UI新建一个按钮小组件作为模版 3-Pause Menu Template Button 继续做更多模版UI 4-Lose Screen(游戏失败UI) 做失败的UI 之前按钮模版的调度程序就在这起…

C语言初阶牛客网刷题——HJ100 等差数列【难度:简单】-20250123

1. 题目描述——HJ100 等差数列 牛客网OJ题链接—HJ100等差数列 等差数列 2&#xff0c;5&#xff0c;8&#xff0c;11&#xff0c;14&#xff0c; … 。&#xff08;从 2 开始的 3 为公差的等差数列&#xff09;&#xff0c;求等差数列前 n 项和。 注意&#xff1a;本题有多…