一个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
万分感谢各位热心朋友的回答,谢谢