根据指标体系数重排序算法

指标体系数
例子:
2
2.3
2.3.1
2.3.4
2.4
2.4.3
2.4.5

public static void changeOrderValueWithNaturalNumber(List<ExportAnnualDataDto> resultList) {if (org.apache.commons.collections4.CollectionUtils.isEmpty(resultList)){return;}// 序号按点分割,取最大的长度,同时将分隔好的字符串数组放入对应的dto中,避免后续使用的时候浪费资源Integer max = resultList.stream().peek(e->e.setOrderArr(org.apache.commons.lang3.StringUtils.split(e.getOrder(), "."))).map(e -> e.getOrderArr().length).max(Comparator.comparingInt(e -> e)).get();// 根据序号的第一个值分组然后排序Map<Integer, List<ExportAnnualDataDto>> collect = resultList.stream().collect(Collectors.groupingBy(e -> Integer.valueOf(e.getOrderArr()[0]), TreeMap::new,Collectors.toList()));// 第一位的数据int firstNum=1;// 遍历分组集合for (Map.Entry<Integer, List<ExportAnnualDataDto>> entry : collect.entrySet()) {// 每一组的数据List<ExportAnnualDataDto> value = entry.getValue();// 按位的自然数顺序排序sort(max,value);// 获取最大数组的长度Integer maxLength = value.stream().map(e -> e.getOrderArr().length).max(Comparator.comparingInt(e -> e)).get();// 创建int数组,对应每一位序号的值int[] formatArr = new int[maxLength];// 固定第一位序号的值formatArr[0] = firstNum;// 记录上一次的长度int lastLength =-1;// 遍历每一组的数据for (int i = 0; i < value.size(); i++) {ExportAnnualDataDto dataDto = value.get(i);// 获取当前数据的顺序位数int length = dataDto.getOrderArr().length;// 非第一次if (i!=0){// 当前长度小于上一次的长度if (lastLength>length) {// 将当前长度之后的位所在数据清零,重新计算for (int j =length; j < maxLength; j++) {formatArr[j]=0;}}}if (length!=1){// 如果不是第一位,则在当前位数上加1formatArr[length-1]=(formatArr[length-1])+1;}// 根据位数拼接新的序号StringJoiner joiner = new StringJoiner(".");for (int j = 0; j < length; j++) {joiner.add(String.valueOf(formatArr[j]));}// 将新的序号更新回实体中dataDto.setOrder(joiner.toString());// 将当前长度设置为上一次长度,用于下一次循环比较lastLength = length;}// 第一位数据的值加1firstNum++;}// 整体返回的值进行排序sort(max, resultList);// 移除Order数组resultList.forEach(e->e.setOrderArr(null));}private static void sort(Integer max, List<ExportAnnualDataDto> list) {Comparator<ExportAnnualDataDto> comparing = Comparator.comparing(o -> Integer.valueOf(o.getOrderArr()[0]));for (int i = 1; i < max; i++) {final int index = i;comparing = comparing.thenComparing(Comparator.nullsFirst(Comparator.comparing(o -> {if (o.getOrderArr().length > index) {return Integer.valueOf(o.getOrderArr()[index]);} else {return 0;}})));}list.sort(comparing);}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/835494.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

会计之友杂志社投稿信箱邮箱

《会计之友》杂志杂志投稿信箱&#xff1a;kjzyzzhsh126.com 《会计之友》杂志杂志投稿信箱&#xff1a;kjzyzzhsh126.com 咨询电话&#xff1a;13356222771 咨询电话&#xff1a;13356222771 咨询电话&#xff1a;18366155179 咨询电话&#xff1a;18366155179 编辑在…

网络安全复习

概述 重要性 网络安全威胁 OSI安全体系结构 信息与网络安全目标 机密性完整性可用性 五类安全服务 八类安全机制 网络安全体系结构 基本安全设计原则 数据加密技术 2.1数据加密技术概述 2.2经典加密 2.3对称秘钥加密 2.4公开秘钥加密 Diffie-Hellman秘钥交换 对称…

MySQL入门学习-数据类型.文本字符串类型

MySQL中的文本字符串类型主要包括CHAR、VARCHAR、TEXT和BLOB四种类型。 一、文本字符串的特点、使用方法以及与其他类型的比较&#xff1a; 1. CHAR&#xff1a; - 特点&#xff1a;固定长度&#xff0c;最多可以存储255个字符。 - 使用方法&#xff1a;使用时需要指定长度&a…

【DDR 终端稳压器】Sink and Source DDR Termination Regulator [B]

正式从这里开始 TI 的选型&#xff1b; tps54116-q1 tps51200a-q1 TPS53317 典型电路 pin功能EN对于 DDR VTT 应用&#xff0c;请将 EN 连接到 SLP_S3 对于任何其他应用&#xff0c;请使用 EN 作为 ON/OFF 功能 始终保持 EN 电压等于或低于 VIN 电压GND信号接地 连接到输…

2024年成都市标杆场景项目申报条件对象、奖励和认定材料流程

一、申报条件 &#xff08;一&#xff09;申报主体需注册成立两年以上&#xff0c;具备独立法人资格&#xff0c;在成都有固定经营或者生产场地&#xff0c;上两年度主营业务收入年均1000万元以上或上两年度主营业务收入增长率年均10%以上&#xff1b; &#xff08;二&#x…

深度优先搜索(Depth-First Search, DFS)

深度优先搜索&#xff08;Depth-First Search, DFS&#xff09;是一种用于遍历或搜索树形结构&#xff08;如树、图等&#xff09;的算法。它沿着树的深度方向尽可能深地搜索&#xff0c;只有当当前分支无法继续深入时才回退到前一个节点&#xff0c;并尝试其他未被访问的分支。…

活字格中读取粘贴板中的内容:剪切板cp,我手机就吃这一亲!

哟,小伙伴们,今天我们来聊聊一个有趣的小功能吧! 你们应该都熟悉"复制粘贴"这个操作了吧?用CtrlC和CtrlV就可以将文字或图片等内容从一处复制到另一处,方便极了。但是,如果你的设备没有键盘,就没法使用快捷键了,那可怎么办呢? 别急,我们有解决办法!开发应用的时候…

【复利思维 + 项目成功方程式】用1年,超越别人38年!

复利思维—每天进步1%。 一年后会比现在的自己优秀38倍。在做任何事情时都要考虑&#xff0c;这件事是否能随着时间不断积累扩大&#xff0c;不能积累价值的事情要及时调整和止损。 在这个过程中&#xff0c;千万不要陷入心理暗示的陷阱&#xff0c;尤其是越想得到的&#xf…

JVM调参实践总结

JVM调优–理论篇从理论层面介绍了如何对JVM调优。这里再写一篇WIKI&#xff0c;尝试记录下JVM参数使用的最佳实践&#xff0c;注意&#xff0c;这里重点介绍HotSpot VM的调参&#xff0c;其他JVM的调参可以类比&#xff0c;但不可照搬。 Java版本选择 基于Java开发应用时&…

政安晨:【Keras机器学习示例演绎】(四十二)—— 使用 KerasNLP 和 tf.distribute 进行数据并行训练

目录 简介 导入 基本批量大小和学习率 计算按比例分配的批量大小和学习率 政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras机器学习实战 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在…

Excel日期数字转化成时间格式

1、5位数字转化成yyyy/mm/dd 要考虑闰年的小细节 // 输入数字转成日期&#xff08;5位&#xff0c;excel表格日期&#xff09;&#xff0c;默认转换成YYYY-MM-DD export function numberToDate(number, format) {if (number ! undefined) {let date new Date((number - 1) *…

IDEA中的常见注解

下面是对每个注解的详细解释&#xff1a; Override&#xff1a;这个注解用于标记一个方法覆盖或实现了父类或接口中的方法。如果一个方法标记为Override&#xff0c;但实际上没有覆盖或实现父类或接口中的方法&#xff0c;编译器会报错。 Deprecated&#xff1a;这个注解用于标…

机器学习求数组的迹

机器学习求数组的迹、也叫求矩阵的迹。 矩阵的迹&#xff0c;也称为迹数&#xff0c;是矩阵主对角线上所有元素的和。矩阵的迹具有以下重要性质&#xff1a;- 不变性&#xff1a;矩阵的迹在转置、加法、乘法等运算下保持不变。- 特征值关系&#xff1a;一个方阵的迹等于其所有特…

微服务全局异常处理

1.使用两个注解RestControllerAdvice 和 Excetionhandler(valueExcetption.class) 2.第一个注解RestcontrollerAdvice用于注解类&#xff0c;RestControllerAdvice可以捕获整个应用程序中抛出的异常&#xff0c;并对它们进行处理。这样可以实现在整个应用程序范围内统一处理异…

高标准农田建设项目天空地一体化智慧监管平台

一、建设背景 党中央、国务院高度重视高标准农田建设。国务院办公厅印发的《关于切实加强高标准农田建设提升国家粮食安全保障能力的意见》 明确提出&#xff0c;大力推进高标准农田建设&#xff0c;到2022年&#xff0c;建成10亿亩高标准农田&#xff0c;以此稳定保障1万亿斤以…

《C语言文件处理:从新手到高手的跃迁》

&#x1f4c3;博客主页&#xff1a; 小镇敲码人 &#x1f49a;代码仓库&#xff0c;欢迎访问 &#x1f680; 欢迎关注&#xff1a;&#x1f44d;点赞 &#x1f442;&#x1f3fd;留言 &#x1f60d;收藏 &#x1f30f; 任尔江湖满血骨&#xff0c;我自踏雪寻梅香。 万千浮云遮碧…

寻找最大价值的矿堆 - 矩阵

系列文章目录 文章目录 系列文章目录前言一、题目描述二、输入描述三、输出描述四、Java代码五、测试用例 前言 本人最近再练习算法&#xff0c;所以会发布一些解题思路&#xff0c;希望大家多指教 一、题目描述 给你一个由’0’(空地)、‘1’(银矿)、‘2’(金矿)组成的地图…

Spring Cloud Gateway 全局过滤器

系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站&#xff0c;这篇文章男女通用&#xff0c;看懂了就去分享给你的码吧。 全局过滤器作用于所…

TypeScript:JavaScript的超集

什么是TypeScript&#xff1f; TypeScript是一种由Microsoft开发的开源语言&#xff0c;它在JavaScript的基础上增加了类型系统和编译时的类型检查。TypeScript旨在解决JavaScript在大规模应用开发中遇到的问题&#xff0c;特别是在类型安全性方面。它可以编译成纯JavaScript代…

Visual Studio 安装教程 超级详细 (亲测有效)

1.1 VS2019安装 网址&#xff1a;Visual Studio: 面向软件开发人员和 Teams 的 IDE 和代码编辑器 下载完成之后双击.exe文件 步骤严格如下安装 默认语音包为中文&#xff08;简体&#xff09; 安装位置可以自行选择&#xff0c;完成以后就可以点击安装了。 安装完毕以后需要重…