统计list集合中相同名称的元素个数

一个list集合,不确定长度,其中的元素包括名称、数量两项。按名称处理,将名称相同的数量相加进行统计,但是这么写好像有问题啊,求指点

 List<QuestionTypeSettingVO> qtSettings;
QuestionTypeSettingVO qtSetting;
if (null != qtSettings && qtSettings.size() > 0) {
            for (int j = 0; j < qtSettings.size()-1; j++) {
                qtSetting = qtSettings.get(j);
                if (j > 0) sb.append(",");
                for(int k = j+1; k < qtSettings.size(); k++){
                    if(qtSetting.getQuestionType()==qtSettings.get(k).getQuestionType()){
                            sb.append("\"").append(qtSetting.getQuestionType()).append("\":")
                         .append(qtSetting.getTotalQuestionCount()+qtSettings.get(k).getTotalQuestionCount());  
                    }else{
                                    sb.append("\"").append(qtSetting.getQuestionType()).append("\":")
                                    .append(qtSetting.getTotalQuestionCount()); 
                                }
                            }
                        }
                    }

List qtSettings;
Map qts = new HashMap();
if (null != qtSettings && qtSettings.size() > 0) {
for (QuestionTypeSettingVO qtSetting:qtSettings) {
if(qts.containsKey(qtSetting.getQuestionType())){
qts.get(qtSetting.getQuestionType).setTotalQuestionCount(qtSetting.getTotalQuestionCount() + qts.get(qtSetting.getQuestionType).getTotalQuestionCount());
}else{
qts.put(qtSetting.getQuestionType(), qtSetting);
}
}
}
然后你要的信息都在qts里面

你现在的逻辑不应该用sb.append 改成 replace 找到名称相同的数据替换并更新数量。这样就可以了

如果对性能不做要求的话,这样子好像是最简单的了。

List filist = new ArrayList();
Set set = new HashSet();
for(int i = 0; i < list.size(); i++)
{
set.add(list.getName());
}
String[] arr = (String[])set.toArray();
for(int i = 0; i < arr.length; i++)
{
int sum = 0;
for(int j = 0; j < list.size(); j++)
{
if(arr[i].equals(list.get(j).getName()))
{
sum+=list.get(j).getNum();
}
}

            filist.add(new Ob(arr[i],sum));

}

就是利用set去重,然后两个for循环就出来了...

http://blog.csdn.net/qq_35473951/article/details/54136744
看下这个能能不能帮助你

统计list集合中相同名称的元素个数,之前有个面试题目就是,据说是用treemap

万分感谢各位热心朋友的回答,谢谢