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
    评论
//插入排序 List insertSort(List list){ for(int i = 2;i <= list.getLength(); i ++){ list.getList()[0] = list.getList()[i];//复制为哨兵 int j; for(j = i-1;other.lower(list.getList()[0],list.getList()[j]);j -- ){ list.getList()[j + 1] = list.getList()[j]; }//记录后移 list.getList()[j + 1] = list.getList()[0];//插入到正确位置 } return list; } //折半插入排序 List BInsertSort(List list){ for(int i = 2; i <= list.getLength(); i ++){ list.getList()[0] = list.getList()[i];//暂存,不是哨兵作用了 int low = 1,high = i -1; while(low <= high){//折半查找要插入的位置 int m = (low + high) / 2; if(other.lower(list.getList()[0],list.getList()[m])) high = m - 1; else low = m + 1; } for(int j = i -1; j >= high + 1; j --){ list.getList()[j +1] = list.getList()[j];//记录后移 } list.getList()[high + 1] = list.getList()[0]; } return list; } //希尔排序 List shellSort(List list,int t){ int[] temp = new int[t];//增量数组 for(int i = t - 1,j = 1; i >= 0 ; i --,j += 2){ temp [i] = j; }//构造增量数组,确保最后一个元素值为1 for(int k = 0; k < t; k ++){ shellInsert(list,temp[k]);//增量为temp[k] } return list; } //一趟的希尔排序 void shellInsert(List list,int k){ //对顺序表作一趟希尔插入排序 for(int i = k + 1; i <= list.getLength(); i ++){ list.getList()[0] = list.getList()[i];//暂存,不作哨兵 int j; for(j = i - k; j > 0 && other.lower(list.getList()[0],list.getList()[j]); j -= k){ list.getList()[j + k] = list.getList()[j];//记录后移 } list.getList()[j + k] = list.getList()[0]; } //return list; } //冒泡排序 List bubbleSort(List list){ boolean change = true;//一个交换标志,当为false时,表示已排序int temp; for(int i = list.getLength();i >= 2 && change; i --){ change = false; for(int j = 1; j < i; j ++ ){ if(other.lower(list.getList()[j + 1], list.getList()[j])){//两个元素逆序,交换 temp = list.getList()[j + 1]; list.getList()[j + 1] = list.getList()[j]; list.getList()[j] = temp; change = true; } } } return list; } //快速排序 List quickSort(List list){ return QSort(list,1,list.getLength()); } //交换list子表的记录,使枢轴记录到位,并返回此位,在此位之前的记录均小于它,之后的记录均大于它 int partition(List list,int low,int high){ list.getList()[0] = list.getList()[low];//用子表第一个元素作枢轴,0元素为暂存枢轴 int pivotKey = list.getList()[low]; while(low < high){ while(low < high && list.getList()[high] >= pivotKey) -- high; list.getList()[low] = list.getList()[high]; while(low < high && list.getList()[low] <= pivotKey) ++ low; list.getList()[high] = list.getList()[low]; } list.getList()[low] = list.getList()[0]; return low; } //递归形式 List QSort(List list,int low,int high){ int pivotKey; if(low < high){ pivotKey = partition(list,low,high); QSort(list,low,pivotKey - 1);//递归 QSort(list,pivotKey + 1, high); } return list; } //简单选择排序 List selectSort(List list){ int j; int temp; for(int i = 1;i < list.getLength(); i ++){// j = selectMinKey(list,i);//初始化后再使用 if( i != j){ temp = list.getList()[j]; list.getList()[j] = list.getList()[i]; list.getList()[i] = temp; } } return list; } //选择最小的 int selectMinKey(List list, int k){ int min = k;// for(int i = k ; i <= list.getLength();i ++){ if(other.lower(list.getList()[i],list.getList()[min])) min = i; } return min; }
### 回答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、付费专栏及课程。

余额充值