LinkedHashMap 是 java 中的预定义类,类似于 HashMap 。 LinkedHashMap 和 HashMap 之间的唯一区别是 LinkedHashMap 保留插入顺序,而 HashMap 不保留插入顺序。 LinkedHashMap 在 java 中可以转换为两个数组,其中一个数组用于 LinkedHashMap 中的键,另一个数组用于值。
例子:
Input : LinkedHashMap = [2=6, 3=4, 5=7, 4=6] Output: Array of keys = [2, 3, 5, 4] Array of Values = [6, 4, 7, 6] Input : LinkedHashMap = [1=a, 2=b, 3=c, 4=d] Output: Array of keys = [1, 2, 3, 4] Array of Values = [a, b, c, d]
算法:
- 使用键和相应的值在 LinkedHashMap 中进行输入。
- 创建一个数组,数据类型与 LinkedHashMap 中的键相同。
- 创建另一个数组,其数据类型与 LinkedHashMap 中的值相同。
- 开始LinkedHashMap遍历。
- 将每个键和值复制到两个数组中。
- 遍历完成后,打印两个数组。
下面是上述方法的实现:
Java
// Java Program to Convert LinkedHashMap to Two Arrays
import java.io.*;
import java.util.*;
class GFG {
public static void main(String[] args)
{
LinkedHashMap<Integer, Integer> lhm
= new LinkedHashMap<>();
lhm.put(2, 6);
lhm.put(3, 4);
lhm.put(5, 7);
lhm.put(4, 6);
lhm.put(6, 8);
Integer[] Keys = new Integer[lhm.size()];
Integer[] Values = new Integer[lhm.size()];
int i = 0;
// Using for-each loop
for (Map.Entry mapElement : lhm.entrySet()) {
Integer key = (Integer)mapElement.getKey();
// Add some bonus marks
// to all the students and print it
int value = ((int)mapElement.getValue());
Keys[i] = key;
Values[i] = value;
i++;
}
// printing all the element of array contain keys
System.out.print("Array of Key -> ");
for (Integer key : Keys) {
System.out.print(key + ", ");
}
// iterate value array
System.out.println();
System.out.print("Array of Values -> ");
for (Integer value : Values) {
System.out.print(value + ", ");
}
}
}
输出
Array of Key -> 2, 3, 5, 4, 6, Array of Values -> 6, 4, 7, 6, 8,
时间复杂度:在)
相关用法
- Java LinkedHashMap转List用法及代码示例
- Java LinkedHashMap containsValue()用法及代码示例
- Java LinkedHashMap entrySet()用法及代码示例
- Java LinkedHashMap forEach()用法及代码示例
- Java LinkedHashMap getOrDefault()用法及代码示例
- Java LinkedHashMap keySet()用法及代码示例
- Java LinkedHashMap values()用法及代码示例
- Java LinkedHashMap containsKey()用法及代码示例
- Java LinkedHashMap get()用法及代码示例
- Java LinkedHashMap removeEldestEntry()用法及代码示例
- Java LinkedHashMap clear()用法及代码示例
- Java LinkedHashSet spliterator()用法及代码示例
- Java LinkedHashSet add()用法及代码示例
- Java LinkedHashSet clear()用法及代码示例
- Java LinkedHashSet clone()用法及代码示例
- Java LinkedHashSet contains()用法及代码示例
- Java LinkedHashSet containsAll()用法及代码示例
- Java LinkedHashSet equals()用法及代码示例
- Java LinkedHashSet hashCode()用法及代码示例
- Java LinkedHashSet isEmpty()用法及代码示例
- Java LinkedHashSet remove()用法及代码示例
- Java LinkedHashSet removeAll()用法及代码示例
- Java LinkedHashSet retainAll()用法及代码示例
- Java LinkedHashSet size()用法及代码示例
- Java LinkedHashSet toArray()用法及代码示例
注:本文由纯净天空筛选整理自sambhavshrivastava20大神的英文原创作品 How to Convert LinkedHashMap to Two Arrays in Java?。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。