【LeetCode】初级算法案例+java代码(设计问题篇)

简介: 【LeetCode】初级算法案例+java代码(设计问题篇)

@TOC


# 一、打乱数组 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/2b9ee960eec34a509bc1805e9524e24d.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) ```java class Solution { int[] nums; // 用以打乱的数组 int[] tempArr; public Solution(int[] nums) { this.nums = nums.clone(); tempArr = nums.clone(); } public int[] reset() { return nums; } // 随机两两互换进行打乱 public int[] shuffle() { int r1 = new Random().nextInt(nums.length); int r2 = new Random().nextInt(nums.length); int temp = tempArr[r1]; tempArr[r1] = tempArr[r2]; tempArr[r2] = temp; return tempArr; } } ```
# 二、最小栈 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/f9b6335d660744ffa4d6c35ec415e5f6.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAV1NLSDA5Mjk=,size_20,color_FFFFFF,t_70,g_se,x_16) ```java class MinStack { //链表头,相当于栈顶 private ListNode head; //压栈,需要判断栈是否为空 public void push(int x) { if (empty()) { head = new ListNode(x, x, null); } else { head = new ListNode(x, Math.min(x, head.min), head); } } //出栈,相当于把链表头删除 public void pop() { if (empty()) { throw new IllegalStateException("Stack is Empty"); } head = head.next; } //栈顶的值也就是链表头的值 public int top() { if (empty()) { throw new IllegalStateException("Stack is Empty"); } return head.val; } //链表中头结点保存的是整个链表最小的值,所以返回head.min也就是 //相当于返回栈中最小的值 public int getMin() { if (empty()) { throw new IllegalStateException("Stack is Empty"); } return head.min; } //判断栈是否为空 private boolean empty() { return head == null; } } class ListNode { public int val; public int min;//最小值 public ListNode next; public ListNode(int val, int min, ListNode next) { this.val = val; this.min = min; this.next = next; } } ```
目录
相关文章
|
5月前
|
Java 开发工具
【Azure Storage Account】Java Code访问Storage Account File Share的上传和下载代码示例
本文介绍如何使用Java通过azure-storage-file-share SDK实现Azure文件共享的上传下载。包含依赖引入、客户端创建及完整示例代码,助你快速集成Azure File Share功能。
456 6
|
6月前
|
IDE Java 关系型数据库
Java 初学者学习路线(含代码示例)
本教程为Java初学者设计,涵盖基础语法、面向对象、集合、异常处理、文件操作、多线程、JDBC、Servlet及MyBatis等内容,每阶段配核心代码示例,强调动手实践,助你循序渐进掌握Java编程。
799 3
|
6月前
|
安全 Java 应用服务中间件
Spring Boot + Java 21:内存减少 60%,启动速度提高 30% — 零代码
通过调整三个JVM和Spring Boot配置开关,无需重写代码即可显著优化Java应用性能:内存减少60%,启动速度提升30%。适用于所有在JVM上运行API的生产团队,低成本实现高效能。
751 3
|
5月前
|
Java 数据处理 API
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
320 115
|
5月前
|
安全 Java 编译器
为什么你的Java代码需要泛型?类型安全的艺术
为什么你的Java代码需要泛型?类型安全的艺术
232 98
|
5月前
|
安全 Java 容器
告别繁琐判空:Optional让你的Java代码更优雅
告别繁琐判空:Optional让你的Java代码更优雅
|
5月前
|
安全 Java 容器
告别空指针噩梦:Optional让Java代码更优雅
告别空指针噩梦:Optional让Java代码更优雅
466 94
|
5月前
|
设计模式 算法 搜索推荐
Java 设计模式之策略模式:灵活切换算法的艺术
策略模式通过封装不同算法并实现灵活切换,将算法与使用解耦。以支付为例,微信、支付宝等支付方式作为独立策略,购物车根据选择调用对应支付逻辑,提升代码可维护性与扩展性,避免冗长条件判断,符合开闭原则。
1108 35
|
5月前
|
Java 编译器 API
java最新版和java8的区别,用代码展示
java最新版和java8的区别,用代码展示
464 43
|
5月前
|
存储 算法 搜索推荐
《数据之美》:Java数据结构与算法精要
本系列深入探讨数据结构与算法的核心原理及Java实现,涵盖线性与非线性结构、常用算法分类、复杂度分析及集合框架应用,助你提升程序效率,掌握编程底层逻辑。

热门文章

最新文章