我有一个作为键和HashMap
作为值的。String
List
的名称HashMap
是pageMap
。
假设这pageMap
具有以下键和值:
key = order
value = [page1, page2, page3]
现在我想以以下模式显示:
order
page1
page2
page3
key2
value1
value2
value3
value4
请告诉我该怎么做?
我有一个作为键和HashMap
作为值的。String
List
的名称HashMap
是pageMap
。
假设这pageMap
具有以下键和值:
key = order
value = [page1, page2, page3]
现在我想以以下模式显示:
order
page1
page2
page3
key2
value1
value2
value3
value4
请告诉我该怎么做?
import java.util.*;
import java.lang.*;
public class StringListMapExample {
public static String asTreeFormattedString(HashMap<String,List<String>> map) {
final StringBuilder builder = new StringBuilder();
for (String key : map.keySet()) {
builder.append(key + "\n");
for (String string : map.get(key)) {
builder.append("\t" + string + "\n");
}
}
return builder.toString();
}
public static void main(String[] args) {
HashMap<String, List<String>> map = new HashMap<String, List<String>>();
map.put("order", Arrays.asList(new String[]{"page1", "page2", "page3"}));
System.out.println(asTreeFormattedString(map));
}
}
public String formatDictionary(Map<String, List<String>> map){
String output = '';
for (String key : map.keySet()){
output = output + key + "\n";
for (String value: map.get(s)){
output = output + "\t" + value + "\n";
return output
这与 Jeppi 的答案非常相似,但使用了字符串连接,这是我最喜欢的 Java 之一。我没有运行任何基准测试,但我的猜测是他的会快一点,但我的开销会更少。
实际上,解决方案非常简单。
hashmap.get(key).iterator();
是给定键列表的迭代器。
你为什么不试着自己弄清楚呢?
Iterate using iterator through all keys of hashmap using keyset()
{
print key
Iterate through value list using iterator
{
print each value
}
}