我正在做一個分配,我必須搜索TreeMap中的鍵(映射到它們被發現的文件。基本上,這個TreeMap是一個反轉索引),它以一個查詢單詞開始,程序在查詢文件中。但是,爲了提高效率,我們的教授不希望在查找以查詢詞開頭的鍵時遍歷TreeMap中的所有鍵,而是希望我們只遍歷我們需要遍歷的鍵。例如,如果查詢詞以C開頭,那麼我們應該只遍歷以C開頭的鍵。有關如何處理這個問題的任何想法?如何遍歷TreeMap的一部分?
0
A
回答
1
使用TreeMap的subMap()
方法來獲取SortedMap,其中只包含您想要檢查的鍵的範圍。然後遍歷SortedMap。
0
下面是基本實現什麼@ottomeister建議:
public class Tester{
public static void main(String a[]){
TreeMap<CustomObject,String> tm = new TreeMap<CustomObject,String>();
tm.put(new CustomObject(4,"abc"),"abc");
tm.put(new CustomObject(7,"bcd"),"bcd");
tm.put(new CustomObject(25,"cde"),"cde");
tm.put(new CustomObject(18,"def"),"def");
tm.put(new CustomObject(2,"efg"),"efg");
tm.put(new CustomObject(8,"fgh"),"fgh");
tm.put(new CustomObject(3,"aab"),"aab");
tm.put(new CustomObject(13,"aab"),"abb");
Map<CustomObject, String> sub = tm.subMap(new CustomObject(9,""),new CustomObject(20,""));
for(Map.Entry<CustomObject,String> entry : sub.entrySet()) {
CustomObject key = entry.getKey();
String value = entry.getValue();
System.out.println(key.getId() + " => " + value);
}
}
}
class CustomObject implements Comparable<CustomObject>{
private int id;
private String Name;
CustomObject(int id, String Name){
this.id = id;
this.Name = Name;
}
@Override
public int compareTo(@NotNull CustomObject o) {
return this.id - o.id;
}
public int getId(){
return this.id;
}
}
輸出: 13 => ABB 18 =>高清
相關問題
- 1. 如何遍歷一個TreeMap直到一個特定的鍵?
- 2. 只遍歷地圖的一部分
- 3. 消耗串的部分,而遍歷它
- 4. 遍歷ejs部分中的JSON對象
- 5. 阻止jQuery遍歷文檔的部分
- 6. AST樹的遍歷特定部分
- 7. 遍歷java中的大部分列表
- 8. 如何遍歷一個DataTable
- 9. 如何遍歷一個pyspark.sql.Column?
- 10. jQuery遍歷一個表格的一部分
- 11. 如何遍歷
- 12. 如何遍歷Swift中字典的特定部分?
- 13. 如何遍歷Word文檔的各個部分?
- 14. 如何遍歷文件夾中的文件 - 第II部分?
- 15. 如何遍歷這個複雜的數據結構的一部分?
- 16. 遍歷列表理解中的列表的一部分
- 17. 遍歷樹 - 分步
- 18. 如何部分和漸進地遍歷JavaScript對象?
- 19. 如何遍歷多個分支
- 20. Rails 5 - 遍歷視圖數組的一部分
- 21. Python:遍歷列表的一部分以查找素數
- 22. 如何遍歷SAFEARRAY **
- 23. 如何遍歷int [] []?
- 24. 如何遍歷MultiKeyMap?
- 25. 如何遍歷JsonObject?
- 26. 如何遍歷priority_queue?
- 27. 如何遍歷QStringList
- 28. 如何遍歷System.Windows.SystemParameters?
- 29. 如何遍歷JSON?
- 30. 如何遍歷scalaz
我想你的意思是在Java TreeMap的?你能更準確地描述TreeMap的關鍵嗎?你也可以更具體地說「只有我們需要的鑰匙」嗎?但是,通常情況下,TreeMap只能完全迭代。 – nplatis 2012-04-21 23:12:03
是的,Java TreeMap。對不起,這些鍵是TreeMap中的字符串類型,所以我只想遍歷以與查詢詞相同的字母開頭的鍵。根據我的教授,有許多方法可以遍歷TreeMap的一部分,但我試圖用這種方法來處理它(假設它是可能的)。這有助於澄清嗎? – maxicecil21 2012-04-21 23:20:17