我正在尝试对列表进行排序,但是比较器有问题。我的列表是A,我正在尝试按某个int进行排序,但出现错误...而且我无法使用lamda表达式或继承...任何帮助...
代码:
List<?> sortbenefitList = new ArrayList();
List<SelectItem> sortedBenefitList = new ArrayList<SelectItem>();
Map<String,Integer> map=new HashMap<String, Integer>();
for(IBen benefit : benefitList){
Collections.sort(benefitList, benefit.getStartSegmentNumber());
SelectItem item = new SelectItem();
item.setValue(benefit.getBenefitId().toString());
item.setLabel(benefit.getStartSegmentNumber().toString());
sortedBenefitList.add(item);
}
if(sortedBenefitList != null && !sortedBenefitList.isEmpty()){
Collections.sort(benefitList, benefit.getStartSegmentNumber().toString()) {
public int compare(SelectItem a1, SelectItem a2) {
String a1Lebel = a1.getLabel();
String a2Lebel = a2.getLabel();
Integer a1Int = Integer.parseInt(a1Lebel);
Integer a2Int = Integer.parseInt(a2Lebel);
a1Int.compareTo(a2Int)
map.put();
return a1Int.compareTo(a2Int);
}
});
}
以上是我的代码。
答案 0 :(得分:0)
您的代码应如下所示: 您不需要2个列表。只有一个。 sort方法将对传递的列表进行排序
twoSum(new int[] {4,5,7,5},10)
您也可以使用比较int:
List<SelectItem> benefitList = new ArrayList<SelectItem>();
//add items
Comparator<SelectItem> comparator = (o1, o2) -> Integer.compare(Integer.parseInt(o1.getLabel()), Integer.parseInt(o2.getLabel()));
Collections.sort(benefitList, comparator);
或如果不能使用lambda则使用匿名类
Comparator<SelectItem> comparator = Comparator.comparingInt(o -> Integer.parseInt(o.getLabel()));