[英]How can I add an Map Entry to an ArrayList?
I'm creating an ArrayList of Map Entry key-value pairs. 我正在创建Map Entry键值对的ArrayList。 This is so I can store lots of individual words (as a key) and save the total number of times they are used (as the value).
这样我就可以存储大量单个单词(作为键)并保存它们的总次数(作为值)。
I need to be able to sort the ArrayList by value so I can order the words by their values. 我需要能够按值对ArrayList进行排序,以便我可以按其值排序单词。
I have 2 problems: 我有两个问题:
Any help much appreciated! 任何帮助非常感谢!
protected void addKeywords(Status status) {
// get tweet
String str = status.getText();
// split into an array remove punctuation and make lower case
String[] splited = str.replaceAll("[^a-zA-Z ]", "").toLowerCase()
.split("\\s+");
// vars used in loop
String thisStr;
int wordTot;
Entry<String, Integer> newEntry = null;
for (int i = 0; i < splited.length; i++) {
// get word from array
thisStr = splited[i].toLowerCase();
thisStr = "hi";
// if this is the first word to be added
if (mapList.size() == 0) {
//this is the syntax that I don't know!
newEntry.key = theStr;
newEntry.value = 1;
mapList.add(newEntry);
} else {
boolean alreadyExists = false;
//iterate through mapList
for (Entry<String, Integer> entry : mapList) {
// already exists
if (entry.getKey() == thisStr) {
wordTot = entry.getValue();
//increment the value
wordTot++;
entry.setValue(wordTot);
break;
}
}
//if we have reached here the value must not be in the arraylist so add it
//again - this is the syntax that I don't know!
newEntry.key = theStr;
newEntry.value = 1;
mapList.add(newEntry);
}
}
}
-EDIT - working code Hi, I've added the new code to add map entries to the ArrayList and that is working great. -EDIT - 工作代码嗨,我添加了新的代码,将地图条目添加到ArrayList,这很有效。
I have also updated my sort code and this is working great too: 我还更新了我的排序代码,这也很有效:
private void sortMap() {
Collections.sort(mapList, new Comparator<Map.Entry<String, Integer>>() {
@Override
public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
if (o1.getValue()>o2.getValue()){
return 1;
}else if (o1.getValue()<o2.getValue()){
return -1;
}else{
return 0;
}
}
});
}
List<Map.Entry<String, String>> list = new ArrayList<Map.Entry<String, String>>();
list.add(new AbstractMap.SimpleEntry<String, String>("foo", "bar"));
Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
@Override
public int compare(Map.Entry<String, String> o1, Map.Entry<String, String> o2) {
return 0;
}
});
Consider the contract of the compare
method: 考虑
compare
方法的合同:
Compares its two arguments for order.
比较它的两个参数的顺序。 Returns a negative integer, zero, or a positive integer as the first argument is less than, equal to, or greater than the second.
返回负整数,零或正整数,因为第一个参数小于,等于或大于第二个参数。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.