Java -【字符串,数组,哈希表】常用操作

一. 字符串

  1. 创建字符串:
    可以使用双引号或者String类的构造方法创建字符串。
String str1 = "Hello World";
String str2 = new String("Hello World");
  1. 连接字符串:
    可以使用加号或者String类的concat()方法连接字符串。
String str3 = str1 + str2;
String str4 = str1.concat(str2);
  1. 获取字符串长度:
    可以使用length()方法获取字符串的长度。
int len = str1.length();
  1. 获取字符串中的字符:
    可以使用charAt()方法获取字符串中指定位置的字符。
char c = str1.charAt(0);
  1. 截取字符串:
    可以使用substring()方法截取字符串。
String sub = str1.substring(0, 5);
  1. 替换字符串:
    可以使用replace()方法替换字符串中的字符或子串。
String newStr = str1.replace("World", "Java");
  1. 转换字符串大小写:
    可以使用toUpperCase()和toLowerCase()方法将字符串转换为全大写或全小写。
String upper = str1.toUpperCase();
String lower = str1.toLowerCase();
  1. 搜索字符串:
    可以使用indexOf()方法查找字符串中指定字符或子串的位置。
int index = str1.indexOf('o');
int index2 = str1.indexOf("World");
  1. 比较字符串:
    可以使用equals()方法比较字符串是否相等。
boolean isEqual = str1.equals(str2);
  1. 格式化字符串:
    可以使用String.format()方法将数据格式化为字符串。
String name = "小明";
int age = 20;
String info = String.format("姓名:%s,年龄:%d", name, age);
  1. 遍历字符串
String str = "Hello world!";
for (int i = 0; i < str.length(); i++) {
    char c = str.charAt(i);
    System.out.println(c);
}

String str = "Hello world!";
for (char c : str.toCharArray()) {
    System.out.println(c);
}

二. 数组 - 列表

  1. 创建数组:
    可以使用初始化语句或new关键字创建数组。
int[] a = {1, 2, 3};
int[] b = new int[3];
  1. 获取数组长度:
    可以使用length属性获取数组长度。
int len = a.length;
  1. 访问数组元素:
    可以使用下标操作符[]访问数组元素。
int element = a[0];
  1. 修改数组元素:
    可以通过下标操作符[]修改数组元素。
a[1] = 4;
  1. 遍历数组:
    可以使用for循环或者foreach语句遍历数组。
for (int i = 0; i < a.length; i++) {
    System.out.println(a[i]);
}

for (int element : a) {
    System.out.println(element);
}
  1. 数组复制:
    可以使用Arrays类的copyOf()方法或System.arraycopy()方法复制数组。
int[] c = Arrays.copyOf(a, 3);
int[] d = new int[3];
System.arraycopy(a, 0, d, 0, 3);
  1. 反转列表:
    可以使用Collections类的reverse()方法对列表进行反转。
Collections.reverse(a);
  1. 数组排序:
    可以使用Arrays类的sort()方法对数组进行排序。
// 正序
Arrays.sort(a);

// 倒序,可以先正序再反转
Collections.reverse(a); 
  1. 数组查找:
    可以使用Arrays类的binarySearch()方法对有序数组进行查找。
String str = Arrays.toString(a);

三. 哈希表HashMap - 字典

  1. 创建哈希表
HashMap<String, Integer> hashMap = new HashMap<>();
  1. 插入元素
hashMap.put("apple", 5);
hashMap.put("banana", 6);
  1. 获取元素
Integer appleValue = hashMap.get("apple"); // 返回5
  1. 删除元素
hashMap.remove("apple");
  1. 获取哈希表大小
int size = hashMap.size();
  1. 判断哈希表是否为空
boolean isEmpty = hashMap.isEmpty();
  1. 判断哈希表是否包含某个键或值
boolean containsKey = hashMap.containsKey("apple");
boolean containsValue = hashMap.containsValue(6);
  1. 清空哈希表
hashMap.clear();
  1. 遍历哈希表
for (String key : hashMap.keySet()) {
    Integer value = hashMap.get(key);
    System.out.println(key + ": " + value);
}
  1. 排序
HashMap<Integer, Integer> hashMap = new HashMap<>();
hashMap.put(3, 30);
hashMap.put(1, 10);
hashMap.put(2, 20);

List<Map.Entry<Integer, Integer>> list = new ArrayList<>(hashMap.entrySet());
Collections.sort(list, new Comparator<Map.Entry<Integer, Integer>>() {
    public int compare(Map.Entry<Integer, Integer> o1, Map.Entry<Integer, Integer> o2) {
        return o1.getValue().compareTo(o2.getValue());
    }
});

for (Map.Entry<Integer, Integer> entry : list) {
    System.out.println(entry.getKey() + ": " + entry.getValue());
}

这里我们先将哈希表中的元素转换为一个 List,然后通过 Collections.sort() 方法对 List 进行排序,具体排序方式通过传入 Comparator 实现。最后,遍历排好序的 List 输出结果即可。

以上就是关于Java -【字符串,数组,哈希表】常用操作的基本介绍,希望对你有做帮助!

你可能感兴趣的:(Java,java,散列表,python)