2018华为软件精英挑战赛总结
早在被淘汰的时候,就想写一波总结了,还是忍到了比赛结束。
1.初赛赛题
整个赛题主要分为两部分,“利用稀疏的少量数据预测接下来一段时间的销量”+“二维装箱问题”。
最开始我以为整个赛题的难点在第一部分,后来发现并不是。。。因为数据实在是太少了、太稀疏了,用一些模型得到的效果可能还没有用平均数的效果好,所以其实考硬实力的主要是第二部分。
第一部分,我先后使用了“众数”、“MLP”、“随机森林”、“平均数”、“中位数”、“线性回归”、“岭回归”、“带一些约束的岭回归”,发现效果最好的是最后一个,其次是“平均数”。使用每天给的100次机会疯狂调参。。。
第二部分,先是想了想如何用dp,后来师兄提出了一个更好的思路,就是用最优化的方法去解。这个题目中的“二维装箱”问题可以看做一个“整数规划”问题,可以使用“分支限界法”或者“割平面法”得到最优解,我这里使用的是割平面法。
就这样水水的进入了复赛。
2.复赛赛题
复赛赛题增加了难度,修改了数据规模,同时出现了“高级样例”,对我使用的方法带来的影响就是:
①.第一部分要针对初中高级数据分别调参。
②.第二部分对整体使用一次“割平面法”时间消耗太大,得另辟蹊径。
针对第一个问题,没什么好说的,分三种情况疯狂调参。
针对第二个问题,必须在“高利用率”和“低时间效率”进行一个权衡,我在代码中先是加入了一个函数,用来限制第二部分代码执行的时间,赛题给的时间是90s,我将第二部分限制为80秒,防止超时。然后,第二部分怎么做的呢?共有三种不同的“箱子”,我一个箱子一个箱子的放。对于三种不同的“箱子”,先尝试将所有“货物”放进一台第一(二、三)种箱子,箱子有时候会放不满,放不满的情况下利用小“货物”对箱子进行填充,然后看哪种箱子的利用率最高,选择利用率最高的,作为第一个箱子。迭代上述过程,每次放的时候都对三种箱子进行尝试,一直到“货物”放完。在一个箱子一个箱子放的时候使用“割平面法”(也可以使用dp,我测试了,各有好处,有时割平面快,有时dp快)。最后在所有“货物”都放完之后,再整体对“箱子”进行一次扫描,使用各类flavor进行填充(虽然预测出的flavor我们已经放完了,但是我们预测的又不一定准是吧)。
复赛差点出线,很遗憾。
2018华为软件精英挑战赛总结相关推荐
- 2018华为软件精英挑战赛
今天12点,历时一个多月的2018华为软件精英挑战赛训练赛结束了,最后分数215.597(总分300),很遗憾,前64都没能进,不过还算尽力坚持到最后. 3月初,华为软赛开始一周后,看到师兄他们在弄, ...
- 2018华为软件精英挑战赛-模拟退火算法
2018年的华为软件精英挑战赛题目简介:给出华为云虚拟机过去的租借数量历史数据,用以训练模型并预测下一个时间段里的虚拟机租借数量,然后把这些预测得到的虚拟机装填进一定规格的物理机中,即分为预测和装填两 ...
- 2018华为软件精英挑战赛总结及代码
// 我是分割线君 2019复赛结束,成渝季军,深圳决赛见 交流加wei: lidian1993 // 我是分割线君 先贴上我们的名次,我们是成渝赛区的[OB观光团]队,在下是队长[无力吐槽的 ...
- 2018华为软件精英挑战赛经验(一)
初赛.复赛.比赛耗时50天.忙忙碌碌.紧紧张张. 西北赛区真的很强,最终成绩初赛6/64 复赛6/36.真是666!!! 简单说一下赛题: 赛题围绕两个点展开:销量预测问题.放置优化问题. 请求 预测 ...
- # 2021华为软件精英挑战赛C/C++——build.sh/build_and_run.sh/CodeCraft_zip.sh注释
2021华为软件精英挑战赛C/C++--build.sh/build_and_run.sh/CodeCraft_zip.sh注释 1.build.sh #!/bin/bashSCRIPT=$(read ...
- 2021华为软件精英挑战赛(附赠线下判题器链接)——经历
2021华为软件精英挑战赛(附赠线下判题器链接)--经历 1.题目解析 本次赛题源自现实的互联网企业面临的问题,怎样购买与部署服务器最便宜! 服务器:不相同型号的服务器有着不同的CPU与不同的内存,每 ...
- 2023华为软件精英挑战赛,探寻软件人才与科技创新的最优解
作者 | 曾响铃 文 | 响铃说 今天,软件行业正呈现出江河入海一般的大汇流趋势. 一方面是技术的汇流,诸如人工智能等前沿技术与软件行业的深度融合,正全面颠覆软件产品的开发模式和服务逻辑. 另一方面则 ...
- 2016华为软件精英挑战赛:赛题及其答疑汇总
注:本文文字均摘自官方指定网站和论坛,权威且可信,答疑见中间部分,非常全,众玩家可放心阅读. 同时文末给出了包括自己在内的诸多玩家的解法. 前言 赛题源自"未来网络"业务发放中的路 ...
- 2021华为软件精英挑战赛,思路框架,欢迎留言讨论
2021华为软件精英挑战赛,思路框架. 1.对数据初始化封装 服务器 用集合来进行封装,集合由字符串和数组组成键值对 {"服务器型号":[cpu内核,内存,硬件价格,能耗]} 例如 ...
最新文章
- ListMapSet的操作和遍历
- 科大星云诗社动态20210818
- 一般图带权多重匹配(欧拉图+最小费用流)
- mysql 查询两张表结构相同的数据库_利用反射处理多个表结构相同的数据的查询和数据库表的关联...
- 第八节:ES6为数组做了哪些扩展?
- Nginx应用场景之动静分离
- 【clickhouse】clickhouse Exception: Table is in readonly mode
- oem718d 基准站设置_千寻cors账号参数设置完成,RTK手簿显示浮动或单点伪距,能不能进行测量?...
- 2021-02-23 天地图图层类型总结
- list自定义排序工具类
- Java实现mysql的读写分离
- 浅谈Johnson算法
- 图书馆管理系统的c语言,图书馆管理系统 c语言.doc
- 2023南京工业大学计算机考研信息汇总
- java导出excel图片,数据库中图片如何导出到excel表格-Java 怎么把服务器中的图片导出到excel(图片的路......
- CMU SDK-mosi多模态数据使用笔记(一)
- 前端实现打电话、发短信邮件
- Linux服务器连接校园网
- MapReduce -----MapReduce 调优
- 如何提取出word里的图片
热门文章
- 解析C/C++的预处理指令
- 在stringgrid的drawcell事件处理过程中,给单元格赋值时,要用textout输出,不要像一般给cell[i,j]赋值那样。
- visual studio 2008快捷键大全 收藏
- 细说HTML元素的ID和Name属性的区别
- eclipse无法运行 ,报错:the selection cannot be launched
- ubuntu 64上的GCC如何编译32位程序
- Struts2学习总结三
- 「 Modbus-RTU报文解析」解析03、06、10功能码报文示例
- 五、Netty核心组件
- STM32开发 -- CAN总线详解