java8 排序boolean型和int型等

package com.eerdc.diy.service.impl;

import com.alibaba.fastjson.JSONObject;
import lombok.Data;
import org.testng.collections.CollectionUtils;

import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;

public class Test {

    public static void main(String[] args) {

        List<User> userList = new ArrayList<>();
        User user = new User();
        user.setName("zzz");
        user.setAge(12);
        user.setSelected(false);
        User user1 = new User();
        user1.setName("aaa");
        user1.setAge(14);
        user1.setSelected(true);
        User user2 = new User();
        user2.setName("www");
        user2.setAge(8);
        user2.setSelected(false);
        userList.add(user);
        userList.add(user1);
        userList.add(user2);

    //按boolean反排序,按年龄正序    userList.sort(Comparator.comparing(User::isSelected).reversed().thenComparing(User::getAge));
      
        userList.stream().forEach(a -> a.setNoList(new ArrayList<>()));
        userList.forEach(System.out::println);
          System.out.println(JSONObject.toJSONString(userList));
             //按boolean反排序,按年龄反排序  
        List<User> userList2 = userList.stream()
                .sorted(Comparator.comparing(User::isSelected).reversed()
                        .thenComparing(Comparator.comparing(User::getAge).reversed()))
                .collect(Collectors.toList());
        userList2.forEach(System.out::println);

    }
    
}


@Data
class User {

    private List<String> noList;

    private String name;

    private Integer age;

    private boolean isSelected;

}

结果
User(noList=[], name=aaa, age=14, isSelected=true)
User(noList=[], name=www, age=8, isSelected=false)
User(noList=[], name=zzz, age=12, isSelected=false)
[{“age”:14,“name”:“aaa”,“noList”:[],“selected”:true},{“age”:8,“name”:“www”,“noList”:[],“selected”:false},{“age”:12,“name”:“zzz”,“noList”:[],“selected”:false}]
User(noList=[], name=aaa, age=14, isSelected=true)
User(noList=[], name=zzz, age=12, isSelected=false)
User(noList=[], name=www, age=8, isSelected=false)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 冒泡排序是一种相对简单的排序算法,它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。对于int类型Java,可以使用如下代码来实现冒泡排序。 // 设置一个标志,若为true,则表示此次循环没有进行交换,也就是待排序列已经有序,排序已然完成。 boolean flag = false; // 对数组进行冒泡排序 for (int i=0; i<array.length-1; i++) { for (int j=0; j<array.length-1-i; j++) { if (array[j] > array[j+1]) { int temp = array[j]; array[j] = array[j+1]; array[j+1] = temp; flag = true; } } if (!flag) break;//若没有发生交换,则退出循环 } ### 回答2: 冒泡排序是一种基本的排序算法,通过多次比较相邻元素的大小,将较大(或较小)的元素逐渐交换到右侧,从而将最大(或最小)的元素冒泡到最右侧,然后对剩下的元素重复这个过程,直到所有元素按照要求排序完成。 在Java中,实现冒泡排序可以使用一个int类型的数组来存储待排序的数列。排序的步骤如下: 1. 获取待排序数组的长度n。 2. 使用两重循环,外层循环控制需比较的次数,内层循环进行相邻元素的比较和交换。 3. 外层循环的次数为n-1次,表示需要n-1次比较才能将最大(或最小)的元素放到正确的位置。 4. 内层循环从0开始,每次比较相邻的两个元素,如果前一个元素大于(或小于)后一个元素,则交换它们的位置。 5. 内层循环每进行一次,都会将最大(或最小)的元素冒泡到当前未排序的最右侧位置。 6. 重复执行外层循环和内层循环,直到所有元素按照要求排序完成。 以下是一个示例代码实现: ``` public class BubbleSort { public static void bubbleSort(int[] arr) { int n = arr.length; for (int i = 0; i < n-1; i++) { for (int j = 0; j < n-i-1; j++) { if (arr[j] > arr[j+1]) { int temp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = temp; } } } } public static void main(String[] args) { int[] arr = {64, 34, 25, 12, 22, 11, 90}; bubbleSort(arr); System.out.println("排序后的数组:"); for (int num : arr) { System.out.print(num + " "); } } } ``` 这段代码实现了冒泡排序的功能。待排序的数组为int类型的数组,通过调用bubbleSort()方法进行排序,最后将排序结果打印输出。运行代码后,输出的结果为:11 12 22 25 34 64 90,表示数组已按照从小到大的顺序排序完成。 ### 回答3: 冒泡排序是一种简单的排序算法,用于将一个数组按照升序或降序排列。以下是int类型java实现: ```java public class BubbleSort { public static void bubbleSort(int[] arr) { int n = arr.length; for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (arr[j] > arr[j + 1]) { // 交换arr[j]和arr[j+1] int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } public static void main(String[] args) { int[] arr = {64, 34, 25, 12, 22, 11, 90}; bubbleSort(arr); System.out.println("冒泡排序结果:"); for (int num : arr) { System.out.print(num + " "); } } } ``` 在这段代码中,`bubbleSort`方法接收一个int类型的数组作为参数,并对数组进行升序排序。通过嵌套的两个for循环,遍历数组并比较相邻的元素。如果前一个元素大于后一个元素,则交换它们的位置。通过多次遍历和比较,最大(或最小)的元素会逐渐“冒泡”到数组的末尾。最后,打印排序结果。 以上就是使用java实现int类型的冒泡排序的代码和解释。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值