IDC

一个排名调整问题恶心了我整整一天

作者:admin 2021-04-09 我要评论

问题回顾 在招投标行业,某个项目的某个标段会有多家投标人来投标.为了选出中标企业,会组织专家对投标人进行评审,在最后阶段,如果有特殊原因允许对投标人排名进行...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

问题回顾


在招投标行业,某个项目的某个标段会有多家投标人来投标.为了选出中标企业,会组织专家对投标人进行评审,在最后阶段,如果有特殊原因允许对投标人排名进行临时调整

如上图所示,我们可以点击排名按钮,在弹框中选择期望的排名,对投标人排名进行调整;

问题分析

🙌场景一

假如我们将第一名调整为第二名,那么第二名和第一名要对调位置,第三名保持不变,最终变为右侧顺序

🙌场景二

假如我们把第三名调整为第一名,那么原来的第一名和第二名的排名要递减1,最终变为右侧顺序

🤦‍♀️以我浅薄的知识,感觉这个问题很棘手

刚开始我想我需要先把原来的排名查询出来,然后分上面两种情况去判断,进而获取各个元素的新排名,在建立旧排名和新排名的关联,然后通过这个关联关系达到更新数据库的目的

虽然这样也可以做,但我最近放弃了这种方式,采用引入链表来实现,下面来一起看看

解决方案

  1.  HashMap<String, Object> params = new HashMap<>(); 
  2.  params.put("projectId", bidder.getProjectId()); 
  3.  params.put("sectionId", bidder.getSectionId()); 
  4.  
  5.  LinkedList<Integertemp = new LinkedList<>(); 
  6.  //查询当前所有投标人排名 
  7.  LinkedList<Bidder> ranks = this.selectBidderRanking(bidder); 
  8.  
  9. //将所有企业旧排名先放入链表中 
  10.  ranks.forEach(i -> { 
  11.      temp.add(i.getBidderId()); 
  12.  }); 
  13.  //移除当前元素[就是跳转排名的那个企业] 
  14.  temp.remove(bidder.getBidderId()); 
  15.  //指定位置插入元素[以新排名为位置,重新插入那个企业] 
  16.  temp.add(Integer.parseInt(bidder.getRank()) - 1, bidder.getBidderId()); 
  17.  
  18.  //更新排名 
  19.  
  20.  for (int i = 0; i < temp.size(); i++) { 
  21.      bidder.setBidderId(temp.get(i)); 
  22.      bidder.setRank(String.valueOf(i + 1)); 
  23.      bidderMapper.updateBidderRank(bidder); 
  24.  } 

在我们刚刚分析的过程中,其实最麻烦的地方就是一个企业排名变化以后,其他的都要跟着变化,通过利用链表,我们只需要关注他的新排名,对应其他元素的升降已经由链表帮我们处理好,我们只需要重新遍历,就可以获取到新的排名。


本文转载自网络,原文链接:https://mp.weixin.qq.com/s/tESlJi_09EdwMdTJYI9gdA

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 强大的鸿蒙开发环境 - DevEco Studio 2

    强大的鸿蒙开发环境 - DevEco Studio 2

  • 用一个开源工具实现多线程 Python 程序

    用一个开源工具实现多线程 Python 程序

  • 学习如何用 C 语言来进行文件输入输出

    学习如何用 C 语言来进行文件输入输出

  • try-catch-finally中的4个巨坑!

    try-catch-finally中的4个巨坑!

腾讯云代理商
海外云服务器