1. 栈和队列 LinkedList

使用push插入元素时【栈】,头部元素peek为栈顶元素
使用addLast插入元素时,头部元素peek为队首元素

通常创建一个对象专精一个数据结构,不要串用

1.1 栈常用方法

// 栈顶插入元素
push(ele)   
// 返回栈顶元素并弹出    
pop()   
//返回栈顶元素但不弹出
peek()    
 

1.2 队列常用方法

Queue:poll、offer、element、peek_queue_poll

Java 中 List 和 ArrayList 的区别 (加入了个人见解)

// 头插
addFirst(ele)		
// 尾插
addLast(ele)
// 获取队列头元素    
getFirst()		
// 获取队列尾元素    
getLast			
// 获取头元素并弹出
poll()			
// 获取尾元素并弹出     
pollLast()		 
// 删除指定索引元素    
remove(index)		
// 返回首次出现某元素的索引
indexOf(ele)				
 

1.3 通用方法

// 清空
clear()				
// 返回大小    
size()			
// 判断是否为空
isEmpty()					
// 得到指定索引元素【栈是从栈顶数下来】
get(index)			
// 改变某索引处的元素
set(index,ele)		
 

2. 链表 ArrayList

Java 中 List 和 ArrayList 的区别及使用

// 默认将元素添加到链表尾,可以通过index添加到指定位置
add(ele)		
// 移除指定位置元素
remove(index)		
// 修改指定位置元素
set(index,element)		
// 得到指定位置元素
get(index)			
// 返回第一次/最后一次出现某元素的索引
indexOf/lastIndexOf(ele)	
//返回大小/是否为空    
size()/isEmpty()			
// 链表变数组    
toArray()			
// 字符串形式输出【若要输出自定义形式,可以遍历后用StringBuilder拼接】
toString()				
 

3. 集合 Set

TreeSet相较于HashSet多了排序功能【排序通过重写Comparator的方法实现】,因此用TreeSet就行

// 集合如果不存在元素ele,则添加此元素
add(ele)			
// 清空
clear()				
// 查询指定元素是否存在,存在返回true
contains(ele)		
// 判空
isEmpty()				
// 如果指定元素在此set中则移除
remove(ele)			
// 返回元素数量
size()			
// 返回一个大于等于当前元素的最小元素【屋顶上一个】,不存在返回null
ceiling(ele)		
// 返回一个小于等于当前元素的最大元素【地板下一个】,不存在返回null
floor(ele)			
// 返回此set中严格大于给定元素的最小元素,不存在返回null
higher(ele)			
// 返回此set中严格小于给定元素的最大元素,不存在返回null
lower(ele)			
// 返回第一个元素
first()			
// 返回最后一个元素
last()					
 

4. 映射 Map

理由同Set,只讲TreeMap,可根据关键字排序

LinkedHashMap会保证遍历时按照插入顺序【默认】或者访问顺序取出

首元素可用map.entrySet().iterator().next().getKey()得到

// 在此映射中关联指定值与指定键
put(key,value)			
// 从此映射中移除指定键的映射关系(如果存在)
remove(key)			
// 清空
clear() 				
// 如果包含指定键,返回true
containsKey(key)		
// 如果包含指定值,返回true
containsValue(value)
// 返回指定键的值,如果不存在返回null
get(key)				
// 返回此映射中当前第一个(最低)键
firstKey()				
// 返回映射中当前最后一个(最高)键
lastKey()				
// 返回大于等于给定键的最小键;如果不存在这样的键,则返回 null
ceilingKey(key)		
// 返回小于等于给定键的最大键;如果不存在这样的键,则返回 null
floorKey(key)	
// 是否空/map大小    
isEmpty()/size()
 

遍历方式

	   TreeMap<Integer, Integer> map = new TreeMap<Integer,Integer>();
        map.put(1, 2);
        for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
			System.out.println("关键字:"+entry.getKey());
			System.out.println("值:"+entry.getValue());
		}
 

5. 大 / 小根堆 PriorityQueue

API:PriorityQueue (Java SE 11 & JDK 11 )

Java PriorityQueue(优先队列)_priorityqueue函数java-CSDN博客

因为其本质是根堆而不是队列,因此遍历输出得到的元素无序,依次弹出根顶元素才有序

// 清空
clear()				
// 如果包含指定元素返回true
contains(ele) 		
// 将指定元素插入此优先队列
offer(ele) 			
// 获取根堆顶元素
peek() 				
// 获取并移除根堆顶元素
poll() 				
// 移除指定元素
remove(ele) 
// 返回元素个数
size() 					
 

大小根堆选择

// 默认为小根堆,大根堆需要重新方法
PriorityQueue<Integer> queue = new PriorityQueue<Integer>(new Comparator<Integer>() {
			@Override
			public int compare(Integer o1, Integer o2) {
                 // 后面比前面大就交换,即大的在前面,就是大根堆
				return o2-o1; 
			}
		});
 

6. 字符串

String用来处理最终结果,StringBuilder用来拼接

6.1 String

// 返回此字符串的长度
length()			
// 判空,当长度为0时返回true
isEmpty()
// 除去任何前导和尾随空格,如果该字符串没有前导或尾随的空格,则返回值为该字符串本身
trim()		
// 返回索引i处的字符,也可以通过toCharArray()转变成数组再遍历
charAt(int i)	
// 按字典顺序比较两个字符串
compareTo(String anotherString)			
// 按字典顺序且不区分大小写比较两个字符串
compareToIgnoreCase(String anotherString)
// 判断两个字符串是否相等,相等返回true否则返回false
equals(String anotherString)
// 同上,不区分大小写
equalsIgnoreCase(String str)		
// 检查是否以某一前缀开始
startsWith(String prefix)		
// 根据指定字符串拆分
split(String regex) 			
// 返回从begin开始到end-1结束的子串
substring(int beginIndex, int end)	
// 将此字符串中的所有字母都换为大写
toUpperCase() 	
// 将此字符串中的所有字母都换为小写
toLowerCase()	
 
// lastIndexOf有类似用法👇
// 返回指定字符在此字符串中第一次出现的索引
indexOf(char ch)			
// 同上,从指定索引开始搜索
indexOf(char ch, int fromindex) 	
// 返回子串在此字符串中第一次出现的索引
indexOf(String str)			
// 同上,从指定索引开始搜索
indexOf(String str, int fromindex)	
// 用s2替换目标字符串中出现的所有s1
replaceAll(String s1,String s2)	
// 用s2替换目标字符串中出现的第一个s1
replaceFirst(String s1,String s2)	
 
// 类方法【即String.xxx】
// 返回 char数组的字符串表示形式
valueOf(char[] data)				
// 返回 char 数组参数的特定子数组的字符串表示形式
valueOf(char[] data,int offset,int count)
// 返回参数【int,boolean...】的字符串表示形式
valueOf(ele)								
 

6.2 StringBuilder

相较于String来说,处理速度更快,所以处理字符串的时候一般使用StringBuilder,最后再通过toString()方法转为字符串

// 构建一个值为str的可变字符串【也可传空参数】
StringBuilder(String str)
// 返回索引i位置的字符
charAt(int i)
// 返回此字符串的长度
length()
// 在此字符串追加str【参数为StringBuilder也可以】
append(String str)
// 在index处插入字符数组c【c也可以是单个字符或者其他类型】
insert(int index, char[] c)	
// 将char的子数组【下标offset开始,长度len】追加到此字符串
append(char[] str, int offset, int len)	
// 移除此序列从start到end-1的字符串
delete(int start, int end)	
// 移除指定索引上的字符
deleteCharAt(int index)	
// 将指定索引处的字符替换为ch
setCharAt(int index, char ch)	
// 将此字符串反转
reverse()			
// 返回此字符串从start开始至length-1结束的String
substring(int start)		
// 返回此字符串从start开始至end-1结束的String
substring(int start, int end)	
// 返回此序列中的String表示形式
toString()		
 
// lastIndexOf有类似用法👇
// 返回子字符串第一次出现的索引
indexOf(String str)		
// 同上,从指定位置查找
indexOf(String str, int fromIndex)
 

7. 工具类

Arrays

// 将arr数组元素变为字符串,一般用于输出看看数组情况,省去遍历的繁琐操作
toString(arr)  		
// arr数组排序,可以传入匿名类Comparator自定义排序方式
sort(arr,new Comparator<T>(){}) 	
// arr数组二分查找(需要排好序)元素ele,返回目标值索引,找不到返回-1			
binarySearch(arr,ele) 	
// 复制arr数组[from,to)位置元素,返回复制好的数组副本
copyOfRange(arr,from,to)
// 使用ele元素将数组填充
fill(arr,ele) 		
// 比较两个数组元素的内容是否完全一致
equals(arr1,arr2) 				
 

Collections

// 仅List可用
// 反转List中的元素
reverse(list) 	
// 按照小到大对链表进行排序【默认】,也可以实现Compartor接口自定义排序
sort(list,new Cpmparator<T>(){}) 
// 将list中的i处元素和j处元素进行交换
swap(list,i,j) 
// list2拷贝到list1,要确保list1有足够空间
copy(list1,list2) 	
// 将list中的A替换成B
replaceAll(list,A,B)	
    
// List和Set都可用
// 返回最大、最小元素
max(list)/min(list) 
// ele出现次数
frequency(list,ele) 
 

Integer

// Boolean,Double等都有类似将字符串转换的方法👇
// 将字符串参数解析为带符号的十进制整数
parseInt(String s) 	
// 将字符串参数解析为第二个参数指定的基数中的有符号正整数
// radix参数不填则默认以十进制数进行解析
parseInt(String s, int radix)  
// 将i转为k进制真值【有正负号】
toString(int i,k) 
 

8. 日期 Calendar

通过设置对象内部字段再通过get方法获得数值

  • YEAR :指示年份

  • MONTH:指示月份

    MONTH 字段是从0月开始计数的,所以12月对应的值是11

  • DAY_OF_MONTH:指示一个月中的某天。

  • DAY_OF_WEEK:指示一个星期中的某天。

  • DAY_OF_YEAR:指示当前年中的天数。

  • DAY_OF_WEEK_IN_MONTH:指示当前月中的第几个星期。

  • HOUR:指示当天中的某小时

  • MINUTE:指示当前小时中的某分钟

  • SECOND:指示当前分钟中的某秒

// 得到Calendar对象
Calendar calendar = Calendar.getInstance();	
// 第一个参数是日期字段,诸如YEAR、MONTH等将给定的日历字段设置为给定值
set(int field, int value)
// 设置日历字段年月日的值
set(int year, int month, int day)
// 获取给定字段的值
get(int field);		
// 以毫秒为单位返回日历时间值
getTimeInMillis() 		
// 根据日历的规则,为给定的日历字段添加或减去指定的时间量
add(int field, int amount)
 

9. 数学工具 Math

// a,b的最值
min(a,b)/max(a,b)
// 返回正确舍入的 double 值的正平方根
sqrt(double a)		
// 绝对值
abs(a)		
// a的b次方,返回一个double类型的数。
pow(double a, double b) 
// 向上取整
ceil(double x)		
// 向下取整
floor(double x)	
// 四舍五入取整
round(double x)	
// 生成一个[0,1)之间的double类型的伪随机数
random()				
// tan,cos与sin类似
// acos(-1)=π
// 正弦值
sin(double a) 
// 反正弦值
asin(double a) 			
 

10. 大数类

// 传入字符串参数直接创建,可以使用=进行同类型赋值
BigInteger a = new BigInteger("123456789101112131415");
BigDecimal c = new BigDecimal("123456.123456");
// 以二进制解析"111110",变为10进制赋值给d
BigInteger d = new BigInteger("111110", 2);	
// 把a转化为16进制的字符串输出
System.out.println(a.toString(16));			
// a对象值+b对象值并将结果返回
a.add(b)
// 减法,同上👆
a.subtract(b) 
// 乘法,同上
a.multiply(b) 
// 除法,同上
a.divide(b)   
// 取余,同上
a.mod(b)
// 最大公因数,同上
a.gcd(b)	
// 最值,同上
a.max(b)/a.min(b)	
// a的b次方
a.pow(b) 
// 比较大小,a大返回1
a.compareTo(b) 
// 把BigInteger 转化为 BigDecimal
toBigDecimal() 
// 把BigDecimal 转化为 BigInteger
toBigInteger() 
 

BigDecimal在乘除时可以指定结果舍入方式

// 只有乘除法才有舍入这个说法
// 向零舍入。 即1.55 变为 1.5 , -1.55 变为-1.5
ROUND_DOWN 
// 向正无穷舍入. 即 1.55 变为 1.6 , -1.55 变为 -1.5
ROUND_CEILING
// 向负无穷舍入. 即 1.55 变为 1.5 , -1.55 变为 -1.6
ROUND_FLOOR
// 四舍五入 即1.55 变为1.6, -1.55变为-1.6
ROUND_HALF_UP 
// 五舍六入 即 1.55 变为 1.5, -1.5变为-1.5
ROUND_HALF_DOWN 
    
// a除b结果四舍五入并保留两位小数返回给c
BigDecimal c = a.divide(b, 2, BigDecimal.ROUND_HALF_UP);
// a保留两位小数并且向0舍入
a = a.setScale(2, BigDecimal.ROUND_DOWN);
 

11. 输入输出

Scanner类较为常用,此处不赘述

BufferedReader

// 初始化一个缓冲输入流
BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
// 读取一个文本行,一般配合split将读取字符串分割,用Integer将其转型
readLine();	
 

BufferedWriter

// 初始化一个缓冲输出流
BufferedWriter out = new BufferedWriter(new OutputStreamWriter(System.out));
// 将a送入输出流中,一般将需要的输出一并放到输出流中,此时并未输出
write(a);
// 刷新输出流,将此时输出流的东西输出
flush();	
 

12. 常用封装算法

12.1 质数判断

大于等于5的_质数_一定和6的_倍数_相邻,1 不是质数

// 判断素数的方法,已知1不是素数,在主函数中去除1即可
public static boolean isPrimeNumber(int n) {
		if (n == 2 || n == 3) {
			return true;
		}
		if ((n - 1) % 6 == 0 || (n + 1) % 6 == 0) {
			// 当前可能是素数
			for (int i = 2; i <= Math.sqrt(n); i++) {
				if (n % i == 0) {
					return false;
				}
			}
			return true;
		} else {
			return false;
		}
	}
 

12.2 最大公因数 / 最小公倍数

// 最大公约数,此法原理为欧几里得算法,可以理解为是发现的一个规律,不必深究
int gcd(int a, int b) {
		return b == 0 ? a : gcd(b, a % b);
}
 
// 最小公倍数=两数之积/两数最大公约数
int lcm(int a, int b) {
		return a * b / gcd(a, b);
}
 

12.3 快速幂

image.png

	// 快速幂
	static int qmi(int a, int b) {
        // 保存结果
		int res = 1;	
		while (b != 0) {
			if ((b & 1) == 1) {	
                // 当前最右边二进制位上有值时,说明当前a值是我们所需要的
				res = res * a;
			}
            // b每次处理完一位后往右移
			b = b >> 1;	
            // b完成一次位移后,a的次方数应当*2才能满足下一次乘数的要求
			a = a * a;	
		}
		return res;
	}
 

image.png

12.4 快速幂求模

详细原理可看快速幂取模

// 原理:(a*c)%mode==((a%mode)*(c%mode))%mode
// 此函数是求(a^b)%mode
	static long Mode(long a, long b, long mode) {
		long sum = 1;
		a = a % mode;
		while (b > 0) {
			if ((b & 1) == 1) { 
				sum = (sum * a) % mode;
			}
			b = b >> 1;
			a = (a * a) % mode;
		}
		return sum;
	}
 

进阶查看:

一篇搞定位运算——java 位运算详解