Java语言Leetcode中常用的一些基础语法

文章目录

  • Java语言Leetcode中常用的一些基础语法
    • 栈与队列
      • 队列
    • 类型转换
      • 字符串与字符数组的转换
      • 数组与 List 的转换
    • 排序
      • 使用 Collections.sort()
      • 使用 List.sort()
      • 自定义对象排序

Java语言Leetcode中常用的一些基础语法

栈与队列

在Java中,栈通常可以通过 java.util.Stack 类来实现。Stack 类继承自 Vector 类,提供了栈特有的操作方法。
栈是一种 后进先出(LIFO, Last In, First Out)结构。栈中的元素按顺序排列,最后加入的元素最先被移除。栈的典型操作包括:

  • push:将元素推入栈顶。
  • pop:移除栈顶元素。
  • peek:查看栈顶元素,但不移除它。
  • isEmpty:检查栈是否为空。

队列

在Java中,队列是通过 java.util.Queue 接口定义的,并有多个实现类。常见的实现类有:

  • LinkedList:最常用的队列实现之一,它实现了 Queue 接口,因此提供了队列操作方法。
  • PriorityQueue:一种基于优先级堆实现的队列,其中的元素是按自然顺序排序或由提供的比较器进行排序的。

常见的队列操作有:

offer(E e):将元素插入队列末尾。如果队列能够接受此元素,则返回 true,否则返回 false。
poll():移除并返回队列头部的元素。如果队列为空,则返回 null。
peek():返回队列头部的元素但不移除它。如果队列为空,则返回 null。
isEmpty():检查队列是否为空。
size():返回队列中的元素个数。

在Java中,优先级队列(PriorityQueue)是基于优先级堆实现的队列,元素按照自然顺序或自定义的比较器排序。默认情况下,PriorityQueue 会使用元素的 自然排序(即实现了 Comparable 接口的对象)。但是,如果你需要自定义排序规则,可以通过传入一个比较器(Comparator)来控制元素的顺序。

import java.util.PriorityQueue;
import java.util.Comparator;class Student {String name;int score;Student(String name, int score) {this.name = name;this.score = score;}@Overridepublic String toString() {return name + ": " + score;}
}public class PriorityQueueWithComparator {public static void main(String[] args) {// 自定义一个Comparator,按学生的分数降序排序Comparator<Student> byScoreDescending = new Comparator<Student>() {@Overridepublic int compare(Student s1, Student s2) {return Integer.compare(s2.score, s1.score); // 分数高的优先}};// 创建优先级队列,并传入自定义的比较器PriorityQueue<Student> queue = new PriorityQueue<>(byScoreDescending);// 向队列中添加学生queue.add(new Student("Alice", 90));queue.add(new Student("Bob", 85));queue.add(new Student("Charlie", 95));// 打印队列中的学生while (!queue.isEmpty()) {System.out.println(queue.poll()); // 按照分数从高到低打印学生}}
}

在Java中,双端队列(Deque, Double-Ended Queue)是一种队列,它允许从两端插入和移除元素。Deque 接口继承自 Queue 接口,并提供了更多的操作方法,使得可以从队列的两端进行元素的添加和删除。

Deque 接口
Deque 接口定义了双端队列的基本操作,包括:

  • addFirst(E e):将元素添加到队列的头部。
  • addLast(E e):将元素添加到队列的尾部。
  • removeFirst():移除并返回队列头部的元素。
  • removeLast():移除并返回队列尾部的元素。
  • getFirst():获取队列头部的元素,但不移除它。
  • getLast():获取队列尾部的元素,但不移除它。
  • offerFirst(E e):将元素插入队列头部,如果队列没有容量,则返回 false。
  • offerLast(E e):将元素插入队列尾部,如果队列没有容量,则返回 false。
  • pollFirst():移除并返回队列头部的元素,如果队列为空,返回 null。
  • pollLast():移除并返回队列尾部的元素,如果队列为空,返回 null。

类型转换

字符串与字符数组的转换

  1. 字符串转字符数组
    可以通过 String 的 toCharArray() 方法将字符串转换为字符数组。

    String str = "hello";
    char[] charArray = str.toCharArray();
    
  2. 字符数组转字符串
    可以通过 String 构造函数将字符数组转换为字符串。

    char[] charArray = {'h', 'e', 'l', 'l', 'o'};
    String str = new String(charArray);
    

数组与 List 的转换

  1. 数组转 List
    可以使用 Arrays.asList() 方法将数组转换为 List。但是要注意,使用 Arrays.asList() 返回的 List 是固定大小的,不支持增加或删除元素。

    String[] array = {"apple", "banana", "cherry"};
    List<String> list = Arrays.asList(array);
    

    对于基本类型数组(如 int[]),需要转换为对应的包装类类型(如 Integer[]):

    int[] arr = {1, 2, 3, 4};
    List<Integer> list = Arrays.stream(arr)  // 将int[]转为Stream.boxed()     // 转换为Stream<Integer>.collect(Collectors.toList());
  2. List 转数组:
    不管是List转数组还是数组转list都可以用for循环赋值实现。

排序

在 Java 中,排序列表(List)通常通过 Collections.sort() 或 List.sort() 方法实现。

使用 Collections.sort()

Collections.sort() 方法是 Java 中最常用的排序方法之一。它按照元素的自然顺序对列表进行排序。该方法是基于归并排序(MergeSort)实现的,因此具有 O(n log n) 的时间复杂度。

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;public class SortListExample {public static void main(String[] args) {List<Integer> list = new ArrayList<>();list.add(5);list.add(2);list.add(8);list.add(1);// 排序列表Collections.sort(list);// 打印排序后的列表System.out.println(list);  // 输出: [1, 2, 5, 8]}
}

使用 List.sort()

List.sort() 是 Java 8 引入的另一种排序方法,它是 List 接口的方法,接受一个 Comparator。它可以用于自定义排序规则。

import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;public class ListSortExample {public static void main(String[] args) {List<Integer> list = new ArrayList<>();list.add(5);list.add(2);list.add(8);list.add(1);// 使用 List.sort() 和自定义比较器进行排序list.sort(Comparator.reverseOrder());  // 按降序排序// 打印排序后的列表System.out.println(list);  // 输出: [8, 5, 2, 1]}
}

自定义对象排序

对于自定义对象(如类的实例),可以通过实现 Comparable 接口来定义排序规则,或者通过传递自定义的 Comparator 对象来控制排序

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;class Person implements Comparable<Person> {String name;int age;Person(String name, int age) {this.name = name;this.age = age;}@Overridepublic int compareTo(Person other) {return Integer.compare(this.age, other.age);  // 按年龄升序排序}@Overridepublic String toString() {return name + ": " + age;}
}public class PersonSortExample {public static void main(String[] args) {List<Person> list = new ArrayList<>();list.add(new Person("Alice", 30));list.add(new Person("Bob", 25));list.add(new Person("Charlie", 35));// 使用 Collections.sort() 按年龄排序Collections.sort(list);// 打印排序后的列表System.out.println(list);  // 输出: [Bob: 25, Alice: 30, Charlie: 35]}
}

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

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

相关文章

C++ STL(三)list

目录 list是什么 构造函数 元素访问 容量操作 修改 迭代器 code实例 实现简单的list forward_list是什么 构造函数 元素访问 容量 修改 迭代器 code实例 实现一个简单的forward_list list是什么 std::list 是 C 标准模板库&#xff08;STL&#xff09;中的一个…

【Maui】系统找不到指定的文件Xamarin.Android.Aapt2.targets

文章目录 前言一、问题描述二、解决方案三、软件开发&#xff08;源码&#xff09;四、项目展示 前言 .NET 多平台应用 UI (.NET MAUI) 是一个跨平台框架&#xff0c;用于使用 C# 和 XAML 创建本机移动和桌面应用。 使用 .NET MAUI&#xff0c;可从单个共享代码库开发可在 And…

sql server 复制从备份初始化数据

参考 &#xff1a; 从备份初始化订阅&#xff08;事务&#xff09; - SQL Server | Microsoft Learn sql server 复制默认是用快照初始化数据的&#xff0c;也支持从备份初始化数据&#xff0c;参考如上

GDidees CMS v3.9.1本地文件泄露漏洞(CVE-2023-27179)

漏洞简介&#xff1a; GDidees CMS v3.9.1及更低版本被发现存在本地文件泄露漏洞&#xff0c;漏洞通过位于 /_admin/imgdownload.php 的 filename 参数进行利用。 漏洞环境&#xff1a; 春秋云镜中的漏洞靶标&#xff0c;CVE编号为CVE-2023-27179 漏洞复现: 进入靶场发现没…

Redis面试题----MySQL 里有 2000w 数据,Redis 中只存 20w 的数据,如何保证 Redis 中的数据都是热点数据?

要保证 Redis 中存储的 20w 数据都是热点数据&#xff0c;可以从数据筛选和数据淘汰两个大的方面来考虑&#xff0c;以下是详细的实现思路和方法&#xff1a; 数据筛选 1. 基于业务规则 分析业务场景&#xff1a;不同的业务场景有不同的热点数据特征。例如&#xff0c;在电商…

【问题记录】Go项目Docker中的consul访问主机8080端口被拒绝

【问题记录】Go项目Docker中的consul访问主机8080端口被拒绝 问题展示解决办法 问题展示 在使用docker中的consul服务的时候&#xff0c;通过命令行注册相应的服务&#xff08;比如cloudwego项目的demo_proto以及user服务&#xff09;失败。 解决办法 经过分析&#xff0c;是…

【第十节】C++设计模式(结构型模式)-Flyweight( 享元)模式

目录 一、问题背景 二、模式选择 三、代码实现 四、总结讨论 一、问题背景 享元模式&#xff08;Flyweight Pattern&#xff09;在对象存储优化中的应用 在面向对象系统的设计与实现中&#xff0c;创建对象是最常见的操作之一。然而&#xff0c;如果一个应用程序使用了过多…

spring boot 2.7 + seata +微服务 降级失败问题修复

文章引流 一个简单而使用的API管理工具 版本号 spring boot 2.7.17 spring-cloud-dependencies 2021.0.8 spring-cloud-circuitbreaker-resilience4j 2.1.7 spring-cloud-starter-alibaba-seata 2021.1 jdk 1.8原因分析 未配置属性 feign.circuitbreaker.enabledtrue # 未…

实现实时数据仓库开源项目

根据你的需求&#xff0c;以下是一些可以实现类似 ClickHouse 的实时数仓功能的项目&#xff0c;这些项目提供了高性能的数据处理和分析能力&#xff0c;适合实时数据仓库的场景&#xff1a; 1. Apache Doris Apache Doris 是一个开源的实时数据仓库&#xff0c;支持高吞吐量…

【字符串】最长公共前缀 最长回文子串

文章目录 14. 最长公共前缀解题思路&#xff1a;模拟5. 最长回文子串解题思路一&#xff1a;动态规划解题思路二&#xff1a;中心扩散法 14. 最长公共前缀 14. 最长公共前缀 ​ 编写一个函数来查找字符串数组中的最长公共前缀。 ​ 如果不存在公共前缀&#xff0c;返回空字符…

Maven的传递性、排除依赖、生命周期、插件

一、Maven的传递性 蓝色背景中的两个jar包是projectA的直接依赖&#xff0c;其余的Jar包是projectA的间接依赖。 projectA可以使用直接依赖&#xff0c;也可以使用间接依赖。 maven-projectB项目引入了maven-projectC(整个项目打成了jar包&#xff09;和junit两个jar包。 ma…

API,URL,Token,XML,JSON是干嘛的

API&#xff0c;URL&#xff0c;Token&#xff0c;XML&#xff0c;JSON是干嘛的 API的作用 API&#xff08;Application Programming Interface&#xff0c;应用程序编程接口&#xff09;是一组定义和协议&#xff0c;用于构建和交互软件应用程序。API允许不同的软件系统之间…

Spring Boot操作MaxComputer(保姆级教程)

目录 引言 一、引入依赖 二、配置文件 application.properties&#xff08;信息用自己的奥&#xff09; 三、实体类User.java 四、UserController 五、UserService 六、UserDao 七、UserDao.xml 八、postman 访问&#xff0c;成功查询数据 附件(修改和删除数据) 引言…

Java【网络原理】(2)初识网络续与网络编程

目录 1.前言 2.正文 2.1TCP协议与UDP协议 2.2socket API进行网络编程 2.2.1DatagramPacket类 2.2.1.1发送数据报 2.2.1.2接收数据报 2.2.1.3获取数据报内容 2.2.1.4设置数据报内容 2.2.2DatagramSocket类 2.2.2.1构造方法 2.2.2.2常用方法 2.2.3具体代码与解释 3…

【Oracle专栏】sqlplus显示设置+脚本常用显示命令

Oracle相关文档&#xff0c;希望互相学习&#xff0c;共同进步 风123456789&#xff5e;-CSDN博客 1.内容概述 本文主要针对oracle 运维中常用知识点进行整理&#xff0c;包括&#xff1a; 1&#xff09;sqlplus模式下&#xff0c;为了方便查询设置相应的行宽、列宽、行数。…

在一台win10专业版设备上使用docker的怪现象

这台设备上&#xff0c;wsl环境无法直接安装docker&#xff0c;必须要在宿主机安装Docker Desktop.然后&#xff0c;在wsl运行前&#xff0c;要先启动docker desktop&#xff0c;否则&#xff0c;你看不到你自己创建的映像。 然后如果没有docker desktop加持&#xff0c;你在尝…

Unity 中Sirenix.OdinInspector 插件常用功能梳理

案例一 public class PracticeAssets : ScriptableObject {[SerializeField][Searchable][ListDrawerSettings(ShowIndexLabels true)][LabelText("练习版数据列表")]public List<PracticeData> Practicies new List<PracticeData>(); } 1. Serialize…

C++ | 面向对象 | 类

&#x1f47b;类 &#x1f47e;语法格式 class className{Access specifiers: // 访问权限DataType variable; // 变量returnType functions() { } // 方法 };&#x1f47e;访问权限 class className {public:// 公有成员protected:// 受保护成员private:// 私有成员 }…

从零开始用react + tailwindcss + express + mongodb实现一个聊天程序(五) 实现登录功能

1.登录页面 完善登录页面 和注册差不多 直接copy signUpPage 内容 再稍微修改下 import { useState } from "react"; import { useAuthStore } from "../store/useAuthStore"; import { MessageSquare,Mail,Lock,Eye, EyeOff,Loader2} from "lucide…

Spring Boot电影评论网站系统设计与实现

随着互联网和娱乐产业的发展&#xff0c;电影评论网站逐渐成为人们分享观影体验、交流影评的重要平台。本文将介绍一个基于Spring Boot框架开发的电影评论网站系统的功能设计与实现方案。 功能模块概述 该电影评论网站系统分为管理员模块和用户模块两大核心部分&#xff0c;以…