Java刷题API

因为经常用Java刷题,记录一下常用到的API

数组

1. 定义(两种方法)

type arrayName[]; //第一种
type[] arrayName; //第二种
 
//eg
int arrayName[] = new int[5];
int[] arrayName = new int[5];

//二维数组
int arrayName[][] = new int[5][5];
int[][] arrayName = new int[5][5];

type 为Java中的任意数据类型,包括基本类型和引用类型,arrayName为数组名,必须是一个合法的标识符,[ ] 指明该变量是一个数组类型变量,[ ]的数量表示数组的维度,可以有多个,表示多维度数组。Java实际上没有多维数组,只有一维数组。多维数组可以理解为“数组的数组” ,比如二维数组其实是一个一维数组,数组中每个元素是一个一维数组。

2. 初始化

//静态初始化
int[] arr=new int[]{1,2,3};
 
//动态初始化
String[] strArr=new String[3];
strArr[0]="Hello";
strArr[1]="World";
strArr[2]="Hello World";

字符串

1. 创建并初始化

String str = new String("XXX"); //参数可以是字符串常量,也可为字符数组
String str = "XXX"; //参数可为字符串常量,可为String.valueOf()系列的返回值

前者是java中标准的对象创建方式,其创建的对象将直接放置到堆中,每调用一次就会创建一个新的对象;后者则会在栈中创建一个对象引用变量str,然后查看字符串池中是否存在"XXX",如果没有,则将"XXX"存放字符串池,并令引用变量str指向它;如果已经有"XXX",则直接令str指向它。

2. 常用方法

charAt(int index); //返回index位置的字符char --- O(1)
 
length(); //返回字符串长度 --- O(1)
 
substring(int beginIndex, int endIndex); //返回字符片段[beginIndex, endIndex) --- O(n)
substring(int beginIndex); //返回字符片段[beginIndex, end_of_String) 就是从beginIndex开始后面的 ---- O(n)
 
 
indexOf(String str); //返回str第一个出现的位置(int),没找到则返回-1。 --- O(m * n) m为原串长度, n为str长度
s.indexOf(String str, int fromIndex); //同上,但从fromIndex开始找 --- O(m * n)
 
lastIndexOf(String str); //返回str最后出现的位置(int),没找到则返回-1。 --- O(m * n) m为原串长度, n为str长度
lastIndexOf(String str, int fromIndex); //同上,但从fromIndex开始从后往前找 [0 <- fromIndex] --- O(m * n)
 
replace(char oldChar, char newChar); //返回一个新字符串String,其oldChar全部变成newChar --- O(n)
 
toCharArray(); //返回char[]数组。把String变成字符数组 --- O(n)
 
trim(); //去除前后空格的新字符串 --- O(n)
 
split(String regex); //返回String[],以regex(正则表达式)分隔好的字符换数组。 ---- O(n)
//eg:"nanjing" -> [, a, ji, g] (一定要注意,参数可以适合正则表达式的)
String str = "nanjing";System.out.println(Arrays.toString(str.split("n")));
 
toLowerCase(); //返回一个新的字符串全部转成小写 --- O(n)
toUpperCase(); //返回一个新的字符串全部转成大写 --- O(n)

3. java.lang.StringBuilder

  • 创建对象
StringBuilder sb = new StringBuilder();
  • 常用方法
charAt(int index); //返回index位置的char --- O(1)
 
length(); //返回缓冲字符串长度 --- O(1)
 
append(String str); //拼接字符串 --- O(n)
 
toString(); //返回一个与构建起或缓冲器内容相同的字符串 --- O(n)

比较器(关键)


Arrays.sort(people, new Comparator<int[]>() {
    @Override
    public int compare(int[] a, int[] b) {
        if (a[0] == b[0]) {
            return a[1] - b[1]; // 按照k值升序排列
        } else {
            return b[0] - a[0]; // 按照身高降序排列
        }
    }
});


//lambda简化
Arrays.sort(people, (a, b) -> {
    if (a[0] == b[0]) return a[1] - b[1];   // a - b 是升序排列,故在a[0] == b[0]的狀況下,會根據k值升序排列
    return b[0] - a[0];   //b - a 是降序排列,在a[0] != b[0],的狀況會根據h值降序排列
});

集合常用操作

链接: 集合常用方法

各种转换

  • 字符数组转字符串
String.valueOf(chars)
  • 字符串转字符数组
s.toCharArray();
  • 字符串转数字
Integer.parseInt(s);
  • 数字转字符串
String s = String.valueOf(n);
  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值