Java实现剑指Offer中的单例模式与二维数组查找
需积分: 10 98 浏览量
更新于2024-07-20
收藏 501KB PDF 举报
"提供《剑指offer》书中面试题的Java实现,包括单例模式和二维数组中的查找问题。"
在Java编程中,单例模式是一种常见的设计模式,用于确保一个类只有一个实例,并提供一个全局访问点。《剑指offer》中提到了两种单例模式的实现方式,分别是“饿汉式”和“懒汉式”。
1. 饿汉式单例模式
饿汉式单例在类加载时就完成了初始化,因此线程安全。它的实现特点是将实例在类加载时立即创建,确保任何时候获取的都是同一个实例。代码如下:
```java
public class SingletonClass {
private static final SingletonClass instance = new SingletonClass();
// 私有构造函数
private SingletonClass() {}
public static SingletonClass getInstance() {
return instance;
}
}
```
这种方式简单且线程安全,但缺点是如果单例对象不被使用,会造成内存的浪费。
2. 懒汉式单例模式
懒汉式单例延迟了实例的创建,只有当第一次调用`getInstance()`方法时才进行实例化。为了保证线程安全,这里使用了`synchronized`关键字。代码如下:
```java
public class SingletonClass {
private static SingletonClass instance = null;
// 私有构造函数
private SingletonClass() {}
public synchronized static SingletonClass getInstance() {
if (instance == null) {
instance = new SingletonClass();
}
return instance;
}
}
```
懒汉式解决了饿汉式的内存浪费问题,但同步锁会带来性能影响,因为每次调用`getInstance()`都需要进行同步。
面试题3是关于在一个特殊的二维数组中查找指定整数的问题。数组的特性是每一行从左到右递增,每一列从上到下递增。这个问题可以通过双指针法来解决,从数组的右上角开始,根据当前元素与目标值的关系来移动指针。代码如下:
```java
public class Find {
public static boolean find(int[][] array, int number) {
if (array == null) {
return false;
}
int column = array[0].length - 1;
int row = 0;
while (row < array.length && column >= 0) {
if (array[row][column] == number) {
return true;
}
if (array[row][column] > number) {
column--;
} else {
row++;
}
}
return false;
}
// 示例用法
public static void main(String[] args) {
int[][] testArray = new int[4][4];
// 初始化数组...
System.out.println(find(testArray, 5)); // 输出:false
}
}
```
这个算法的时间复杂度为O(m+n),其中m和n分别是数组的行数和列数,因为它最多只需要遍历整个数组一次。在实际应用中,这种算法适用于已排序或部分有序的数据结构,可以快速定位目标值。
2024-03-18 上传
2022-09-24 上传
2022-09-20 上传
2018-07-25 上传
2016-07-12 上传
2021-05-29 上传
2023-09-18 上传
Morphy
- 粉丝: 0
- 资源: 8
最新资源
- Credits-App:积分叠加
- meetup_map_oauth2:使用 OAuth2 通过 Meetup API 获取事件
- 行业分类-设备装置-同时向主叫用户和被叫用户播放多媒体信息的方法.zip
- react todo list and counter:精益应对构建Webapp待办事项列表和计数器应用程序-开源
- 数据库管理
- Manual-Gating
- 行业分类-设备装置-可翻转式台板和用于PCBA测试的机器人上下料系统.zip
- BeatDetectorForGames:用于视频游戏的 C++ 和 C# 节拍检测器。 可以接收歌曲并检测节拍发生的位置,例如在 Vib-Ribbon 等游戏中
- 医学图像分割经典深度学习网络Python代码实现.zip
- MLEM:MLEM库,用于扩展MonoGame
- terraform-aks-devops:使用AzureDevOps设置AKS群集的示例存储库
- 行业分类-设备装置-台式陶瓷三维喷印成形机.zip
- Catwalk:一种使客户能够搜索,浏览,添加到购物车和结帐项目的产品
- FastFileTransfer
- gulp-setup:gulp 的入门项目
- 行业分类-设备装置-可见光无源光充电标签与读写器装置.zip