Java 中將 ArrayList 轉換為 LinkedHashMap
在 Java 中,LinkedHashMap 類 是一種雜湊對映,它允許使用者維護其中元素的有序記錄。此功能還提供了快速插入、搜尋和刪除元素的方法。當我們需要將一個陣列列表 轉換為 LinkedHashMap 時,我們需要為此設定一個鍵值,它會反映為陣列列表的索引。在迭代和資料排序方面,陣列列表和 LinkedHashMap 本質上是相同的。
以下是一個通用示例以及此過程的可能虛擬碼:
Input ArrayList Is Here: { 5, 16, 7, 1997, 2001 }
Output LinkedHashMap Will Be:
Index | Value
1 | 5
2 | 16
3 | 7
4 | 1997
5 | 2001
while (i < l1.size()) {l.put(i + 1, l1.get(i));i++;}
Here, "l1" is a particular ArrayList and "l" is represented as the
LinkedHashMap.
Java 中將 ArrayList 轉換為 LinkedHashMap 的演算法
在此可能的演算法中,我們將向您展示如何對陣列節點執行轉換過程以將其轉換為一組 LinkedHashMap。透過使用此演算法,我們將構建一些Java 語法 來全面瞭解問題陳述。
步驟 1 - 開始此過程。
步驟 2 - 宣告並匯入一些 Java 包。
步驟 3 - 建立一個公共列表。
步驟 4 - 宣告一些鍵作為值。
步驟 5 - 為引用值建立一個建構函式。
步驟 6 - 在列表中分配已宣告鍵的值。
步驟 7 - 返回一些私有變數 ID。
步驟 8 - 宣告一個主要的公共類和方法。
步驟 9 - 宣告引數字串。
步驟 10 - 建立一個數組列表。
步驟 11 - 使用一些資料元素填充列表值。
步驟 12 - 建立並宣告一個 LinkedHashMap 值。
步驟 13 - 宣告物件方法。
步驟 14 - 為 LinkedHashMap 值建立物件。
步驟 15 - 宣告每個資料元素到 LinkedHashMap 中。
步驟 16 - 列印 LinkedHashMap 作為值並終止此過程。
Java 中將 ArrayList 轉換為 LinkedHashMap 的語法
public class Book {
private Integer bookId;
private String title;
private String author;
//getters, setters, constructors, equals and hashcode omitted
}
HashMap<String,HashMap<String,String>> newMap = new HashMap();
for(HashMap<String,String> record : dataList){
String key = record.get("rollno").toString();
newMap.put(key,record);
}
HashMap result = (HashMap<String, HashMap<String, String>>)
listOfHashMaps.stream()
.collect(Collectors.toMap(e-> e.get("roll"),e->e));
list.stream()
.collect(toMap(e->e.get("rollno"), Function.identity()));
在此可能的語法中,我們試圖向您展示如何對陣列節點執行轉換過程以將其轉換為一組 LinkedHashMap。透過這些語法,我們將努力構建一些 Java 程式碼以有效地解決問題陳述。
遵循的方法
方法 1 - 使用 .entrySet()、.toString、流、remove(Object key)、remove(Object key,Object value) 方法將 ArrayList 轉換為 LinkedHashMap 的 Java 程式
方法 2 - 使用 put()、java.util.stream.Collectors 和 this() 方法將 ArrayList 轉換為 LinkedHashMap 的 Java 程式
方法 1
使用 .entrySet()、.toString、流、Remove(Object key)、Remove(Object key,Object Value) 方法
使用 .entrySet() 方法
在此可能的方法中,我們將應用.entrySet() 方法 來執行將陣列列表轉換為一組 LinkedHashMap 的轉換。
List<Student> aListStudent = new ArrayList<Student>();
aListStudent.add(new Student(1, "RUDRA"));
aListStudent.add(new Student(2, "ABONI"));
aListStudent.add(new Student(3, "AHONA"));
aListStudent.add(new Student(4, "ANANDI"));
System.out.println("ArrayList contains are here: " + aListStudent);
Map<Integer, Student> mapStudents =
aListStudent.stream().collect( Collectors.toMap(Student::getId,
student->student));
System.out.println("Map contains are: " + mapStudents);
示例
//Java program to convert an ArrayList to a LinkedHashMap by using the .entrySet() method
import java.util.*;
import java.io.*;
public class ARBRDD{
public static void main(String[] args){
LinkedHashMap<Integer, Integer> l = new LinkedHashMap<>();
ArrayList<Integer> l1 = new ArrayList<>();
l1.add(12);
l1.add(16);
l1.add(7);
l1.add(1997);
l1.add(2001);
int i = 0;
while (i < l1.size()){
l.put(i + 1, l1.get(i));
i++;
}
System.out.println("Key Present In The List | Value Of The Element Is");
for (Map.Entry<Integer, Integer> it :l.entrySet()) {
System.out.println(" " + it.getKey() + " | " + it.getValue());
}
}
}
輸出
Key Present In The List | Value Of The Element Is 1 | 12 2 | 16 3 | 7 4 | 1997 5 | 2001
使用 .toString 和流方法
在此可能的方法中,我們將應用 .toString() 和Java 流 方法來執行將陣列列表轉換為一組 LinkedHashMap 的轉換。
示例
// Java program to convert ArrayList to LinkedHashMap by using .toString and streams method
import java.util.*;
import java.io.*;
import java.util.stream.Collectors;
class integer{
private Integer id;
private String name;
public integer(Integer id, String name){
this.id = id;
this.name = name;
}
public Integer getId() { return this.id; }
public String toString(){
return "[<" + this.id + "=><" + this.name + ">]";
}
}
public class ARBRDD{
public static void main(String[] args){
List<integer> List = new ArrayList<integer>();
List.add(new integer(1, "ARB"));
List.add(new integer(2, "RDD"));
List.add(new integer(3, "DHAKA"));
List.add(new integer(4, "KOLKATA"));
System.out.println("ArrayList contains are here: " + List);
Map<Integer, integer> HashMap =
List.stream().collect(Collectors.toMap(
integer::getId, integer -> integer));
System.out.println("Map contains from the ArrayList are: " +
HashMap);
}
}
輸出
ArrayList contains are here:
[[<1=><ARB>], [<2=><RDD>], [<3=><DHAKA>], [<4=><KOLKATA>]]
Map contains from the ArrayList are:
{1=[<1=><ARB>], 2=[<2=><RDD>], 3=[<3=><DHAKA>], 4=[<4=><KOLKATA>]}
使用 Remove(Object key)、Remove(Object key,Object Value) 方法
在此可能的方法中,我們將應用 remove(Object key) 和 remove(Object key,Object value) 方法來執行將陣列列表轉換為一組 LinkedHashMap 的轉換。
示例
//Java program to convert an ArrayList to a LinkedHashMap and remove the elements from the list by using remove(Object key), remove(Object key,Object value)
import java.util.*;
import java.io.*;
import java.util.LinkedHashMap;
import java.util.Map;
public class ARBRDD{
public static void main(String[] args) {
Map<String, Integer> travelFareMap = new LinkedHashMap<String,
Integer>();
travelFareMap.put("BUS", 1200);
travelFareMap.put("CAR", 2000);
travelFareMap.put("TRAIN", 3500);
travelFareMap.put("AIR PLANE", 14000);
System.out.println(travelFareMap);
Integer fareCar = travelFareMap.remove("CAR");
System.out.println("*************************************");
System.out.println("Vehicle CAR with fare has been "+fareCar+" removed from the HashMap");
System.out.println(travelFareMap);
System.out.println("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
boolean isCarRemoved = travelFareMap.remove("TRAIN",3500);
System.out.println("Did CAR removed from the LinkedHashMap: "+isCarRemoved);
System.out.println(travelFareMap);
System.out.println("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^");
boolean isFlightRemoved = travelFareMap.remove("AIR PLANE",14000);
System.out.println("Did AIR PLANE removed from the LinkedHashMap: "+isFlightRemoved);
System.out.println(travelFareMap);
System.out.println("##################END####################");
}
}
輸出
{BUS=1200, CAR=2000, TRAIN=3500, AIR PLANE=14000}
*************************************
Vehicle CAR with fare has been 2000 removed from the HashMap
{BUS=1200, TRAIN=3500, AIR PLANE=14000}
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Did CAR removed from the LinkedHashMap: true
{BUS=1200, AIR PLANE=14000}
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Did AIR PLANE removed from the LinkedHashMap: true
{BUS=1200}
##################END####################
方法 2
使用 put()、Java.util.stream.Collectors 和 This() 方法。
使用 put() 方法和定義 IllegalArgumentsException
在此可能的方法中,我們將應用put() 方法 來執行將陣列列表轉換為一組 LinkedHashMap 的轉換,並且在這裡我們還定義了 IllegalArgumentsException 的作用。
private static class CompArrayList extends ArrayList<LinkedHashMap<String,
Comparable>> implements Comparable{
@Override
public int compareTo(Object o){
return 0;
}
}
ArrayList<LinkedHashMap<String, Comparable>> y = new
ArrayList<LinkedHashMap<String, Comparable>>();
LinkedHashMap<String, Comparable> x = new LinkedHashMap<String, Comparable>();
示例
//Java program to convert two arrays containing keys and values into a Linked Hash Map by using put() method and define IllegalArgumentsException
import java.util.*;
import java.io.*;
import java.util.LinkedHashMap;
public class ARBRDD{
public static HashMap map(Integer[] keys,
String[] values){
int keysSize = keys.length;
int valuesSize = values.length;
if (keysSize != valuesSize) {
throw new IllegalArgumentException( "The Number Of Keys Doesn't Match The Number Of Values.");
}
if (keysSize == 0) {
return new HashMap();
}
HashMap<Integer, String> map
= new HashMap<Integer, String>();
for (int i = 0; i < keysSize; i++) {
map.put(keys[i], values[i]);
}
return map;
}
public static void main(String[] args){
Integer[] keys = { 1, 2, 3, 4, 5 };
String[] values
= { "Welcome", "To", "Kolkata", "From", "Dhaka" };
Map m = map(keys, values);
System.out.println(m);
}
}
輸出
{1=Welcome, 2=To, 3=Kolkata, 4=From, 5=Dhaka}
使用 Java.util.stream.Collectors 方法
在此可能的方法中,我們將應用 java.util.stream.Collectors 方法來執行將陣列列表轉換為一組 LinkedHashMap 的轉換。
示例
//Java program to convert an ArrayList to a LinkedHashMap by using java.util.stream.Collectors
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.stream.Collectors;
public class ARBRDD{
public static void main(String[] args){
List<HashMap<String, String>> input = new ArrayList<>();
HashMap<String, String> subinput1 = new HashMap<>();
subinput1.put("name", "name1");
subinput1.put("rollno", "rollno1");
input.add(subinput1);
HashMap<String, String> subinput2 = new HashMap<>();
subinput2.put("name", "name2");
subinput2.put("rollno", "rollno2");
input.add(subinput2);
HashMap<String, HashMap<String, String>> result = (HashMap<String, HashMap<String, String>>) input.stream()
.collect(Collectors.toMap(v -> (String) v.get("rollno"), e ->
e));
System.out.println(result);
}
}
輸出
{rollno2={name=name2, rollno=rollno2}, rollno1={name=name1, rollno=rollno1}}
使用 This() 方法
在此可能的方法中,我們將應用 this() 方法來執行將陣列列表轉換為一組 LinkedHashMap 的轉換。
示例
//Java program to convert an ArrayList to a LinkedHashMap by using THIS methed
import java.util.*;
import java.util.LinkedHashMap;
class Book {
int id;
String name,author,publisher;
int quantity;
public Book(int id, String name, String author, String publisher, int quantity){
this.id = id;
this.name = name;
this.author = author;
this.publisher = publisher;
this.quantity = quantity;
}
}
public class ARBRDD {
public static void main(String[] args) {
Map<Integer,Book> map=new LinkedHashMap<Integer,Book>();
Book b1=new Book(101,"Let us C","Yashwant Kanetkar","BPB Publications",8);
Book b2=new Book(102,"Data Communications & Networking","Forouzan","Mc Graw Hill Noida",4);
Book b3=new Book(103,"Operating System","Galvin","Wiley",6);
map.put(2,b2);
map.put(1,b1);
map.put(3,b3);
for(Map.Entry<Integer, Book> entry:map.entrySet()){
int key=entry.getKey();
Book b=entry.getValue();
System.out.println(key+" Details:");
System.out.println(b.id+" "+b.name+" "+b.author+" "+b.publisher+" "+b.quantity);
}
}
}
輸出
2 Details: 102 Data Communications & Networking Forouzan Mc Graw Hill Noida 4 1 Details: 101 Let us C Yashwant Kanetkar BPB Publications 8 3 Details: 103 Operating System Galvin Wiley 6
結論
在 Java 環境中,LinkedHashMap 類是將連結列表和雜湊表結合在 Map 介面上的一個實現過程,並具有適當的迭代過程。此過程繼承 HashMap 類並將其轉換為 Map 介面。在本文中,我們學習瞭如何在 Java 環境中將特定的陣列列表轉換為 LinkedHashMap 集的各種方法。透過使用上述語法和演算法,我們構建了一些 Java 程式碼以有效地解釋問題陳述。
另請參閱: Java 面試問題及答案
資料結構
網路
關係資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 語言程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP