Leetcode 刷题记录 21 —— 技巧

本系列为笔者的 Leetcode 刷题记录,顺序为 Hot 100 题官方顺序,根据标签命名,记录笔者总结的做题思路,附部分代码解释和疑问解答,01~07为C++语言,08及以后为Java语言,一共为 01~21,本系列全部结束。

01 只出现一次的数字

在这里插入图片描述

在这里插入图片描述

class Solution {public int singleNumber(int[] nums) {int result = 0;for(int num : nums){result ^= num;}return result;}
}

位运算

在这里插入图片描述

02 多数元素

在这里插入图片描述

在这里插入图片描述

class Solution {public int majorityElement(int[] nums) {Map<Integer, Integer> map = new HashMap<>();int n = nums.length;int ans = 0;for(int num : nums){if(!map.containsKey(num)){map.put(num, 1);}else{map.put(num, map.get(num) + 1);}}for(int num : nums){if(map.get(num) > (n/2)){ans = num;break;}}return ans;}
}

03 颜色分类

在这里插入图片描述

在这里插入图片描述

class Solution {public void sortColors(int[] nums) {int n = nums.length;int ptr = 0;//第一次遍历,将0交换到头部for(int i=0; i<n; i++){if(nums[i] == 0){int temp = nums[ptr];nums[ptr] = nums[i];nums[i] = temp; ptr++;}}//第二次遍历,将1交换到0之后for(int i=ptr; i<n; i++){if(nums[i] == 1){int temp = nums[ptr];nums[ptr] = nums[i];nums[i] = temp; ptr++;}}}
}

04 下一个排列

在这里插入图片描述

在这里插入图片描述

class Solution {public void nextPermutation(int[] nums) {int len = nums.length;//特殊情况判断if(nums == null || nums.length < 2){return;}int i = len -2, j = len - 1, k = len - 1;while(i >= 0 && nums[i] >= nums[j]){i--;j--;}if(i >= 0){while(nums[i] >= nums[k]){k--;}int temp = nums[i];nums[i] = nums[k];nums[k] = temp;}int left = j, right = len - 1;while(left < right){int temp = nums[left];nums[left] = nums[right];nums[right] = temp;left++;right--;}}
}

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

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

相关文章

Android Studio Meerkat | 2024.3.1 Gradle Tasks不展示

把这两个开关打开&#xff0c;然后刷新gradle文件

Java中方法重写与重载的区别

目录 1. 方法重载 (Overload) 什么是方法重载&#xff1f; 重载的特点&#xff1a; 重载的示例&#xff1a; 重载的调用&#xff1a; 2. 方法重写 (Override) 什么是方法重写&#xff1f; 重写的特点&#xff1a; 重写的示例&#xff1a; 重写的调用&#xff1a; 3.…

微信小程序发送订阅消息-一次订阅,一直发送消息。

实现思路长期订阅要求太高&#xff0c;需要政府、公共交通等单位才有资格&#xff0c;所以只能使用一次性订阅。 就像是买奶茶&#xff0c;下单以后&#xff0c;会弹出让用户订阅消息那种。以买奶茶为例:用户第一次下单成功&#xff0c;点击了订阅消息。&#xff08;一般都有三…

408 Request Timeout:请求超时,服务器等待客户端发送请求的时间过长。

408 Request Timeout 是 HTTP 状态码之一&#xff0c;表示客户端在发送请求时&#xff0c;服务器等待的时间过长&#xff0c;最终放弃了处理该请求。此问题通常与网络延迟、客户端配置、服务器设置或者应用程序的性能有关。1. 常见原因1.1 客户端问题网络连接延迟或不稳定&…

MongoDB面试集锦

该书的使用的MongoDB版本是 4.2.01、什么是NoSQL数据库&#xff1f;NoSQL和RDBMS有什么区别&#xff1f;在那些情况下使用和不使用NoSQL数据库&#xff1f;NoSQL是非关系型数据库&#xff0c;NoSQLNot Only SQL 。关系型数据库采用的是结构化的数据&#xff0c;NoSQL采用的是键…

直击JVM面试题

JVM组成 JVM JVM 就是 Java 程序的运行环境&#xff0c;它通过 类加载、字节码执行、内存管理、GC、线程调度 等机制&#xff0c;让 Java 实现了 跨平台、自动内存管理和高效执行。 它是一个抽象的计算机&#xff0c;能执行以 字节码&#xff08;.class 文件&#xff09; 为单…

地球系统模式(CESM)实践技术应用及进阶

目前通用地球系统模式&#xff08;Community Earth System Model&#xff0c;CESM&#xff09;在研究地球的过去、现在和未来的气候状况中具有越来越普遍的应用。CESM由美国NCAR于2010年07月推出以来&#xff0c;一直受到气候学界的密切关注。近年升级的CESM2.0在大气、陆地、海…

StarRocks导入数据-使用 Broker Load 进行异步导入

目录 一、背景 二、实操 三、查看导入进度 一、背景 将hive库数据表导入starrocks. 二、实操 LOAD LABEL user_behavior (DATA INFILE("hdfs://<hdfs_ip>:<hdfs_port>/user/amber/user_behavior_ten_million_rows.parquet")INTO TABLE user_behavior…

c语言,识别到黑色就自动开枪,4399单击游戏狙击战场,源码分享,豆包ai出品

不好用&#xff0c;识别速度慢&#xff0c;有时候识别不准确#include <windows.h> #include <stdio.h> #include <math.h> HDC hdcScreen; void leftClick(); void RGBtoHSV(int r, int g, int b, int* h, int* s, int* v); int fuzzyFindColor(int x1, int…

电动汽车充电标准之 — SAE J1772“电动汽车传导充电连接器”简介

SAE J1772&#xff08;通常读作 "J seventeen seventy-two"&#xff09;是由美国汽车工程师学会&#xff08;SAE&#xff09;制定的&#xff0c;针对电动汽车传导充电连接器的北美标准。它规范了电动汽车&#xff08;EV&#xff09;与充电设备&#xff08;EVSE&#…

ZooKeeper Multi-op+乐观锁实战优化:提升分布式Worker节点状态一致性

系列文章目录 第一章 ZooKeeper入门概述:Znode,Watcher,ZAB . 第二章 技术解析&#xff1a;基于 ZooKeeper 实现高可用的主-从协调系统&#xff08;通过例子深入理解Zookeeper如何进行协调分布式系统&#xff09; 第三章 基于 ZooKeeper 的主从模式任务调度系统&#xff1a;设…

生产制造过程精益化

一、核心原则&#xff1a;以“消除浪费、创造价值”为核心精益化的本质是通过系统性优化流程&#xff0c;最大化客户价值&#xff0c;最小化资源浪费&#xff08;时间、成本、库存等&#xff09;&#xff0c;核心原则包括&#xff1a;1. 价值导向原则定义客户价值&#xff1a;从…

Ping命令为何选择ICMP而非TCP/UDP?

在网络诊断工具中&#xff0c;ping是最常用的命令之一&#xff0c;它用于测试主机之间的连通性。有趣的是&#xff0c;ping命令并不使用TCP或UDP这些传输层协议&#xff0c;而是基于网络层的ICMP协议。这背后的设计选择体现了计算机网络协议栈的分层智慧和特定用途的优化。ICMP…

VGGNet:为什么16层简单堆叠能成为CNN经典?

配套笔记&讲解视频,点击文末名片获取 研究背景和动机 在 VGG 出现之前,图像识别就像“盲人摸象”: 计算机看一张图,只能凭感觉抓几个零散的“特征点”, 结果忽好忽坏,时灵时不灵。 大家发现,如果把“看图的流程”做得更深、更系统,准确率就能蹭蹭往上涨。于是“深一…

springboot+vue医院诊疗管理系统(源码+文档+调试+基础修改+答疑)

目录 一、整体目录&#xff08;示范&#xff09;&#xff1a; 文档含项目技术介绍、E-R图、数据字典、项目功能介绍与截图等 二、运行截图 三、代码部分&#xff08;示范&#xff09;&#xff1a; 四、数据库表(示范)&#xff1a; 数据库表有注释&#xff0c;可以导出数据…

云蝠智能大模型呼叫新模型上线,拥抱AGI

在人工智能浪潮席卷全球的今天&#xff0c;AGI&#xff08;通用人工智能&#xff09;已不再遥不可及&#xff0c;而是正逐步成为驱动产业变革的核心力量。在这场技术革命中&#xff0c;云蝠智能以其前瞻性的战略布局和技术创新&#xff0c;再次引领行业风向——全新大模型呼叫模…

晨控CK-GW08S-PN与西门子PLC配置Profinet通讯连接操作手册

晨控CK-GW08S-PN与西门子PLC配置Profinet通讯连接操作手册晨控CK-GW08S系列作为晨控智能工业级别网关型RFID读写器,支持大部分工业协议如RS232、RS485、以太网。支持工业协议Modbus RTU、Modbus TCP、Profinet、EtherNet/lP、EtherCat以及自由协议TCP/IP等。本期主题&#xff1…

【Linux】Linux常用指令合集

本文是小编巩固自身而作&#xff0c;如有错误&#xff0c;欢迎指出&#xff01; 目录 一、文件与目录操作 (1) 查看目录&#xff0c;切换目录 pwd ls cd &#xff08;2&#xff09;创建、 删除 mkdir touch rmdir rm cp mv 二、文件的查看及更改 (1)查看和更改 …

MySQL 高级特性与性能优化:深入理解函数、视图、存储过程、触发器

大家好&#xff01;今天我们要深入探讨 MySQL 中一些非常重要的高级主题——内置函数、视图、存储过程、触发器、索引、事务和锁机制。无论你是刚开始学习数据库的新手&#xff0c;还是经验丰富的开发者&#xff0c;掌握这些知识点都将极大提升你的开发效率和数据管理能力。一.…

Linux学习:基于环形队列的生产者消费者模型

目录1. 环形队列的概念与实现方法1.1 环形队列的概念1.2 环形队列的一般实现方法2. 多线程相关的信号量概念与接口2.1 信号量类型2.2 信号量的初始化与销毁2.3 信号量的P申请、V释放操作3. 基于环形队列实现p、c模型的设计方案3.1 环形队列&#xff08;ringqueue&#xff09;作…