「LeetCode Hot 100 题」详解

前言

前言:LeetCode Hot 100 题详解

文章目录

  • 前言
    • 1. 两数之和
    • 2. 字母异位词分组
    • 3. 最长连续序列
    • 4. 移动零

1. 两数之和

  • 原题链接:两数之和

  • 知识点:哈希表

  • 题解

    class Solution {public int[] twoSum(int[] nums, int target) {Map<Integer, Integer> heap = new HashMap<>();  // 哈希表用于记录枚举数的前面所有数for (int i = 0; i < nums.length; i ++ ) {  // 枚举第二个数int another = target - nums[i];if (heap.containsKey(another))  // 查找哈希表中是否存在和为 target 的目标值return new int[] {heap.get(another), i};  // 返回答案对象heap.put(nums[i], i);}return null;}
    }
    

2. 字母异位词分组

  • 原题链接:字母异位词分组
  • 知识点:哈希表
  •   class Solution {public List<List<String>> groupAnagrams(String[] strs) {// 字母相同,但排列不同// 分组标准:将所有字符串排序,判断排序后的是否相等// 哈希表,将 string 映射到 vector 中List<List<String>> res = new ArrayList<>();  // 结果数组Map<String, List<String>> hashMap = new HashMap<>();for (int i = 0; i < strs.length; i ++) {char[] c = strs[i].toCharArray();Arrays.sort(c);String s = new String(c);if (!hashMap.containsKey(s)) hashMap.put(s, new ArrayList<String>());hashMap.get(s).add(strs[i]);}// hashMap.values():返回哈希表中所有值for (List<String> tmp : hashMap.values()) res.add(tmp);return res;}}
    

3. 最长连续序列

  • 原题链接:最长连续序列
  • 知识点:哈希表
  • 题解
    	class Solution {public int longestConsecutive(int[] nums) {// 先将所有数插入到哈希表中,再去枚举所有数// 枚举只枚举每一段的开始,每次枚举完将其删除Set<Integer> hashSet = new HashSet<>();for (int x : nums) hashSet.add(x);int res = 0;for (int x : nums) {if (hashSet.contains(x) && !hashSet.contains(x - 1)) {int y = x;hashSet.remove(x);while (hashSet.contains(y + 1)) {hashSet.remove(++ y);}if (y - x + 1 > res)res = y - x + 1;}}return res;}
    }
    

4. 移动零

  • 原题链接:移动零
  • 知识点:双指针
  • 题解
    	class Solution {public void moveZeroes(int[] nums) {int k = 0;for (int num : nums) {if (num != 0)nums[k ++] = num;}while (k < nums.length) nums[k ++] = 0;}
    }
    

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

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

相关文章

mysql原理--重新认识MySQL

1.MySQL请求处理 1.1.查询缓存 MySQL 服务器程序处理查询请求时&#xff0c;会把刚刚处理过的查询请求和结果缓存起来&#xff0c;如果下一次有一模一样的请求过来&#xff0c;直接从缓存中查找结果就好了&#xff0c;就不用再傻呵呵的去底层的表中查找了。这个查询缓存可以在不…

DOM 事件的传播机制

前端面试大全DOM 事件的传播机制 &#x1f31f;经典真题 &#x1f31f;事件与事件流 事件流 事件冒泡流 事件捕获流 标准 DOM 事件流 &#x1f31f;事件委托 &#x1f31f;真题解答 &#x1f31f;总结 &#x1f31f;经典真题 谈一谈事件委托以及冒泡原理 &#x1f3…

SmartSoftHelp8数据库连接字符串强优化,高并发配置

1.设置数据库是否异步连接 2.数据库连接是否复用 3.最大链接数 4.最小连接数 5.等待时间 6.生命周期 下载地址&#xff1a; 百度网盘 请输入提取码

24、蜂鸣器

蜂鸣器介绍 蜂鸣器是一种将电信号转换为声音信号的器件&#xff0c;常用来产生设备的按键音、报警音等提示信号 蜂鸣器按驱动方式可分为有源蜂鸣器和无源蜂鸣器 有源蜂鸣器&#xff1a;内部自带振荡源&#xff0c;将正负极接上直流电压即可持续发声&#xff0c;频率固定 无源蜂…

【linux】信号——信号保存+信号处理

信号保存信号处理 1.信号保存1.1信号其他相关概念1.2信号在内核中的表示 2.信号处理2.1信号的捕捉流程2.2sigset_t2.3信号集操作函数2.4实操2.5捕捉信号的方法 3.可重入函数4.volatile5.SIGCHLD信号 自我名言&#xff1a;只有努力&#xff0c;才能追逐梦想&#xff0c;只有努力…

Vue2中响应式的原理

Vue2中实现响应式的原理 vue2实现原理Vue2响应式存在的问题 vue2实现原理 使用Object.defineProperty()的get()与set()来实现响应式 <script>let p {}let person {name: "张三",sex:"男",hobby: ["吃饭","睡觉"]}Object.def…

C++:模板进阶

目录 1.非类型模板参数 2. 模板的特化 2.1 概念 2.2 函数模板的特化 2.3 类模板的特化 2.3.1 全特化 2.3.2 偏特化 3. 模板的分离编译 3.1 什么是分离编译 3.2 模板的分离编译 3.3 解决方法 4. 模板总结 1.非类型模板参数 模板参数分类&#xff1a;类型形参与非类…

计算机毕业设计 基于SpringBoot的敬老院管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

数据结构与算法-静态查找表

&#x1f31e; “清醒 自律 知进退&#xff01;” 查找 &#x1f388;1.查找的相关概念&#x1f388;2.静态查找表&#x1f52d;2.1静态查找表的类定义&#x1f52d;2.2顺序查找&#x1f52d;2.3二分查找&#x1f50e;二分查找例题 &#x1f52d;2.4分块查找&#x1f52d;2.5三…

理解BatchNormalization层的作用

深度学习 文章目录 深度学习前言一、“Internal Covariate Shift”问题二、BatchNorm的本质思想三、训练阶段如何做BatchNorm四、BatchNorm的推理(Inference)过程五、BatchNorm的好处六、机器学习中mini-batch和batch有什么区别 前言 Batch Normalization作为最近一年来DL的重…

react 字轮播滚动

一、用计时器来实现 React 字符串滚动轮播&#xff0c;可以使用 setInterval 函数和 React 的生命周期方法来实现。以下是一个简单的示例&#xff1a; import React from "react";export default class TextScroll extends React.Component {constructor(props) {s…

logistic回归详解

为什么不直接统计标签数和预测结果数&#xff0c;计算精度&#xff1f; 因为 存在梯度为0的情况梯度不连续 为什么叫logistic回归 logistic是因为加了一个sigmoid函数&#xff0c;将输出预测值映射到【0&#xff0c;1】 有时候使用MSE损失函数&#xff0c;拟合 有时候使用c…

selenium三猛士

selenium包括三个项目&#xff0c;分别是&#xff1a;Selenium WebDriver,Selenium IDE&#xff0c;Selenium Grid。 Selenium WebDriver Selenium WebDriver是客户端API接口&#xff0c;测试人员通过调用这些接口&#xff0c;来访问浏览器驱动&#xff0c;浏览器再访问浏览器…

利用Python中的Manim进行数学绘画和创作

相信很多同学就算没听过3Blue1Brown&#xff0c;也一定曾看过他们出品的视频&#xff0c;其从独特的视觉角度解说各种数学概念&#xff0c;内容包括线性代数、微积分、神经网络、傅里叶变换以及四元数等晦涩难懂的知识点。例如最火的《线性代数本质》系列视频。 那么这些视频是…

【算法】动态规划中的路径问题

君兮_的个人主页 即使走的再远&#xff0c;也勿忘启程时的初心 C/C 游戏开发 Hello,米娜桑们&#xff0c;这里是君兮_&#xff0c;如果给算法的难度和复杂度排一个排名&#xff0c;那么动态规划算法一定名列前茅。今天&#xff0c;我们通过由简单到困难的两道题目带大家学会动…

CDN加速技术的发展与演进

随着互联网的迅猛发展&#xff0c;用户对于网页加载速度和内容交付的需求也不断增长。为了应对这一挑战&#xff0c;内容交付网络&#xff08;CDN&#xff09;技术应运而生。本文将从 CDN 加速技术的发展角度&#xff0c;探讨其演进历程以及对网络性能的积极影响。 CDN技术的起…

文字、图片免费生成视频和专属数字人,你不来试试吗?

查看生成的效果&#xff1a;AI产生的视频&#xff08;关注公众号&#xff0c;获取精彩内容&#xff09; 您是否想要制作一些令人惊叹的视频&#xff0c;但又没有视频编辑的技能或经验&#xff1f;您是否想要利用人工智能的力量&#xff0c;让您的图片和声音变成动态的视频&…

如何强制任何Android应用程序进入全屏沉浸式模式(无生根)

谷歌在2012年发布了Android版本的Chrome&#xff0c;并且从未费心给它一个全屏模式。如果您厌倦了等待自己喜欢的Android应用程序提供全屏&#xff0c;则可以使用沉浸式模式自行完成。 来吧&#xff0c;谷歌&#xff0c;我真的一直在乞求你多年&#xff01;没有理由不给我们一…

【Go语言反射reflect】

Go语言反射reflect 一、引入 先看官方Doc中Rob Pike给出的关于反射的定义&#xff1a; Reflection in computing is the ability of a program to examine its own structure, particularly through types; it’s a form of metaprogramming. It’s also a great source of …

C语言——深入理解指针(4)

目录 1.回调函数 2. qsort 函数的使用 2.1 排序整型数据 2.2 排序结构体数据 3. qsort 函数的模拟实现 1.回调函数 回调函数就是通过一个函数指针调用的函数。 你把函数的地址作为参数传递给另一个函数&#xff0c;当这个指针被用来调用其所指向的函数时&#xff0c;被调…