一些高效函数笔记

  • int[] ans = Arrays.copyOf(nums, n*2);
  • System.arrayCopy
  • HashMap
  • 关于String
  • 关于StringBuilder
  • Math里常用
  • 位运算
  • substring
  • 新创建数组、列表
  • hashmap相关


int[] ans = Arrays.copyOf(nums, n*2);

Arrays的copyOf()方法传回的数组是新的数组对象,改变传回数组中的元素值,不会影响原来的数组。

copyOf()的第二个自变量指定要建立的新数组长度,如果新数组的长度超过原数组的长度,则保留数组默认值

int[] arr1 = {1, 2, 3, 4, 5}; 
int[] arr2 = Arrays.copyOf(arr1, 5);//1,2,3,4,5
int[] arr3 = Arrays.copyOf(arr1, 10);//1,2,3,4,5,0,0,0,0,0

System.arrayCopy

arraycopy(Object src, int srcPos, Object dest, int destPos, int length)
代码解释:
Object src : 原数组
int srcPos : 从元数据的起始位置开始
Object dest : 目标数组
int destPos : 目标数组的开始起始位置
int length : 要copy的数组的长度

//nums=1,2,3 ans=5,4,3,2,1
System.arraycopy(nums, 0, ans, 1, 3);//ans=5,1,2,3,1

HashMap

新建一个哈希表:Map<String, Integer> freq = new HashMap<String, Integer>();
迭代 HashMap:
可以使用 for-each 来迭代 HashMap 中的元素。
如果你只想获取 key,可以使用 keySet() 方法,然后可以通过 get(key) 获取对应的 value,如果你只想获取 value,可以使用 values() 方法。

// 输出 key 和 value
        for (Integer i : Sites.keySet()) {
            System.out.println("key: " + i + " value: " + Sites.get(i));
        }
下面是遍历Map的四种方法:

public static void main(String[] args) {
 
 
  Map<String, String> map = new HashMap<String, String>();
  map.put("1", "value1");
  map.put("2", "value2");
  map.put("3", "value3");
  
  //第一种:普遍使用,二次取值
  System.out.println("通过Map.keySet遍历key和value:");
  for (String key : map.keySet()) {
   System.out.println("key= "+ key + " and value= " + map.get(key));
  }
  
  //第二种
  System.out.println("通过Map.entrySet使用iterator遍历key和value:");
  Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();
  while (it.hasNext()) {
   Map.Entry<String, String> entry = it.next();
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
  }
  
  //第三种:推荐,尤其是容量大时
  System.out.println("通过Map.entrySet遍历key和value");
  for (Map.Entry<String, String> entry : map.entrySet()) {
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
  }
 
  //第四种
  System.out.println("通过Map.values()遍历所有的value,但不能遍历key");
  for (String v : map.values()) {
   System.out.println("value= " + v);
  }
 }

关于String

获取长度:利用 length()方法可获取字符串长度,如:
String message=“Hi,小a”;
System.out.println(message.length()); //输出 5

获取特定位置的字符:利用charAt(int index) 获取特定下标index的字符,如:
String message=“Hi,小a”;
System.out.println(message.charAt(0)); //输出 H

判断是否为空:isEmpty() 方法返回一个布尔值判断数值是否为空。如:
if("".isEmpty())
System.out.println(“这是一个空字符串”);

检索,int indexOf(int ch) ,返回第一次出现字符ch的位置

返回位于字符串的指定索引处的字符:charAt(i)该字符串的索引从零开始
String s = “Strings are immutable”;
5 char result = s.charAt(8);

关于StringBuilder

StringBuilder strB = new StringBuilder();

strB.append(“123”)/append(‘c’)//字符串连接

strB.deleteCharAt(1)//删除下标为1字符

strB.delete(3,5);删除下标从3到5的字符

Math里常用

Math.abs(x) 函数返回指定数字 “x“ 的绝对值

Math.max(a,b,c)函数返回一组数中的最大值。

位运算

左移( << )、右移(>>)、无符号右移( >>> )、位与( & )、位或( | )、位异或( ^ )、位非( ~ )

(5 & 3);//结果为1
(5 | 3);//结果为7
(5 ^ 3);//结果为6
(~5);//结果为-6

substring

substring(int beginIndex, int endIndex);
Str.substring(4);//str="This is text"→Str.substring(4)输出is text
Str.substring(4, 10) ;//str="This is text"→.substring(4, 10) 输出 is te

新创建数组、列表

数组:int ans[] = new int [nums];
列表:List ans = new ArrayList<>();

hashmap相关

新建:HashMap<Integer, Integer> cnt = new HashMap<Integer, Integer>();
查看key中是否包含元素num:if(cnt.containsKey(nums))
更改键值对为(key:mynum):cnt.put(mykey, mynum);//没有则插入新的
得到value的值:cnt.get(cnt.keySet())