zoukankan      html  css  js  c++  java
  • java-多节点的上下移解决方案

    import java.util.*;
    
    /**
     * @Author 59456
     * @Date 2021/7/24
     * @Descrip 解决离散或者相邻部门上下的问题,时间复杂度O(N)、空间复杂度O(1)
     * @Version 1.0
     */
    public class Solution {
    
        static Short MOVE_UP = 1;
        static Short MOVE_DOWN = 0;
        static List<Long> idList = new ArrayList<>();
        static Set<Long> idSet = new HashSet<>();
        static List<DepartmentMoveDto> departmentMoveDtoList = new ArrayList<>();
    
        static {
            // 设置原始有序数据集
            for(Long i=0L;i<10L;i++){
                DepartmentMoveDto departmentMoveDto = new DepartmentMoveDto();
                departmentMoveDto.setId(i);
                departmentMoveDto.setSort(Short.valueOf(i.toString()));
                departmentMoveDto.setSortIndex(Double.valueOf(i.toString()));
                departmentMoveDtoList.add(departmentMoveDto);
            }
    
            // 设置需要移动的节点id
            // 其中0、1是一个空气泡,5、6是另外一个空气泡
            idList.add(0L);
            idList.add(1L);
            idList.add(5L);
            idList.add(6L);
            idList.add(9L);
    
        }
    
    
        // 逆向思考:另外的节点移动
        public static void move(List<Long> idList,Short moveType,Long parentId){
            if(null == idList || idList.isEmpty()){
                return;
            }
    
            // 获取同级部门排序信息
            //        List<DepartmentMoveDto> departmentMoveDtoList = departmentDao.getDepartmentMoveDtoListByParentId(parentId);
            idSet = new HashSet<>(idList);
    
            if(MOVE_UP.equals(moveType)){
                moveUp(departmentMoveDtoList ,idSet);
            }else {
                Collections.reverse(departmentMoveDtoList);
                moveUp(departmentMoveDtoList ,idSet);
                Collections.reverse(departmentMoveDtoList);
            }
    
    
        }
    
        /**
         * 专门针对上移设计(其实下移也是另外一个视角的上移)
         * 核心思想聚焦需要移动节点,上方相邻的普通节点(本质也可以看做这些节点的向下冒泡)
         * @param departmentMoveDtoList 部门移动信息
         * @param idSet 需要移动的部门id
         */
        private static void moveUp(List<DepartmentMoveDto> departmentMoveDtoList,Set<Long> idSet){
            int length = departmentMoveDtoList.size();
            for(int index = 0; index<length-1; index++){
                DepartmentMoveDto departmentMoveDtoPre = departmentMoveDtoList.get(index);
                Long idPre = departmentMoveDtoPre.getId();
    
                DepartmentMoveDto departmentMoveDtoNext = departmentMoveDtoList.get(index+1);
                Long idNext = departmentMoveDtoNext.getId();
    
                // 如果当前不移动,下一个移动:交换
                if (!idSet.contains(idPre) && idSet.contains(idNext)) {
                    DepartmentMoveDto departmentMoveDtoSwitch = departmentMoveDtoList.get(index);
                    departmentMoveDtoList.set(index, departmentMoveDtoList.get(index + 1));
                    departmentMoveDtoList.set(index + 1,departmentMoveDtoSwitch);
                }
            }
        }
    
    
        public static void main(String[] args) {
            departmentMoveDtoList.forEach(entity->{
                System.out.println(entity.toString());
            });
            System.out.println("hello world!");
    
            // 部门下移
            move( idList, new Short("0"), 0L);
    
            departmentMoveDtoList.forEach(entity->{
                System.out.println(entity.toString());
            });
        }
    
    }
    
    
    探究未知是最大乐趣
  • 相关阅读:
    对同一个对象绑定多个响应事件并都执行
    IO流读取与写入文件+SQL替换更新字段脚本
    去掉所有HTML标记或取出匹配HTML标记间的文本
    CS程序启动后定时循环执行Clock_Elapsed事件Timer控件
    SQL新建登录帐户,并为新帐户建立安全帐户,并授予访问数据库的角色
    WEB服务的调用与调试
    SQL修改约束
    删除数据库的所有存储过程、主键、外键、索引等
    用SQL直接将文件内容导入数据表中
    将上传文件以二进制形式存入数据库中,并下载数据库中的二进制数据生成对应的文件
  • 原文地址:https://www.cnblogs.com/Mufasa/p/15056939.html
Copyright © 2011-2022 走看看