Java List排序:将num为0的元素移到末尾
本文介绍了如何使用Java对Listttt
解决方案:自定义比较器
通过创建自定义比较器,我们可以实现这种排序需求:
立即学习“Java免费学习笔记(深入);
items.sort((o1, o2) -> { int num1 = o1.getitem2().getNum(); int num2 = o2.getitem2().getNum(); if (num1 == 0 && num2 != 0) { return 1; // 将num1为0的元素排在后面 } else if (num1 != 0 && num2 == 0) { return -1; // 将num2为0的元素排在后面 } else { return 0; // num1和num2均为0或不为0,保持原始顺序 } });
该代码使用lambda表达式定义了一个比较器。它首先获得o1和o2的Item2.num值,然后根据num值是否为0进行比较,将num为0的元素排序到最后。
完整的示例代码
以下是一个完整的可操作示例,包括Item、Item2和测试数据:
import java.util.ArrayList; import java.util.List; import java.util.Random; public class ItemSorter { public static void main(String[] args) { List<Item> items = generateSampleData(); System.out.println("排序前:"); printNums(items); items.sort((o1, o2) -> { int num1 = o1.getitem2().getNum(); int num2 = o2.getitem2().getNum(); if (num1 == 0 && num2 != 0) { return 1; } else if (num1 != 0 && num2 == 0) { return -1; } else { return 0; } }); System.out.println(" 排序后:"); printNums(items); } private static void printNums(List<Item> items) { for (Item item : items) { System.out.print(item.getitem2().getNum() + " "); } System.out.println(); } private static List<Item> generateSampleData() { List<Item> items = new ArrayList<>(); Random random = new Random(); for (int i = 0; i < 10; i++) { items.add(new Item(i, "Item " + i, new Item2(i, random.nextInt(3)))); // 在0-2之间生成随机数 } return items; } } class Item { private long id; private String title; private Item2 item2; public Item(long id, String title, Item2 item2) { this.id = id; this.title = title; this.item2 = item2; } public Item2 GetItem2() { return item2; } } class Item2 { long id; int num; public Item2(long id, int num) { this.id = id; this.num = num; } public int getNum() { return num; } }
该示例生成了包含随机num值(包括0)的Item列表,并演示了排序前后num值的差异。 这种方法清晰、简洁、高效地解决了问题。
以上是如何使用Java在List中使用Item2.num为0的元素排到最后?详情请关注图灵教育的其他相关文章!
