2017 华为软件精英挑战赛——思路、算法简介

 2017 华为软件精英挑战赛 初赛赛题

4.5号就结束初赛了,不影响大家的排名,只说大致思路和方法:

       正好研一上学期学习了焦永昌教授的《工程优化》,期末的大作业就是遗传算法分割图像的小论文,所以对启发式算法还是比较熟悉的,如果是西电的小伙伴一定要选这个老师的课啊,给分高讲的还好,关键学的东西还有用!!


1:使用遗传算法,可以参考一下这篇论文:赵国忠, 陈靖一, 凌韬. 遗传算法求最优路径的设计与实现[J]. 计算机与数字工程, 2010, 38(12):33-35+79.

2:使用模拟退火算法,可以参考:MGASA算法求解物流中货物最佳运输路线货

3:其他算法,参考文献:低代价最短路径树的快速算法


上面的几个算法是核心,但是基础的东西也还是很重要,语言就不说了C/C++/JAVA ,算法这方面是主要的基础

1:《算法导论》最大流,可以参考这篇博客:【算法导论】最大流算法

2:如果你和我一样使用C++的STL的话,准备好耐心地调BUG吧

3:数据结构的:树、图等基础概念

4:最小费用流,参考博客:最小费用流,SPFA


大家加油,这是一个很好的锻炼机会,虽说不一定拿名次,但是主要是得到了解决问题的能力吧,我自己也是一个小白,但是自己理解题目问题,理解相关概念(数据结构:图、费用流),搜文献,查算法,实现算法,优化算法达到要求(毕竟只有90s),再优化拿大奖~~~享受过程嘛~~~。



赛题包下载(包含测试相关):http://download.csdn.net/detail/misayaaaaa/9802802


本次赛题基本描述:(官网也有

       在给定结构的G省电信网络中,为了视频内容快速低成本的传送到每个住户小区,需要在这个给定网络结构中选择一些网络节点附近放置视频内容存储服务器。需要解决的问题是:在满足所有的住户小区视频播放需求的基本前提下,如何选择视频内容存储服务器放置位置,使得成本最小。
本次赛题通用性描述
       网络结构模型:给定一个由若干网络节点(例如路由器、交换机)构成的网络结构无向图,每个节点至少与另外一个节点通过网络链路相连(网络链路特指两个网络节点之间直接相连的网络通路,中间没有其他网络节点,相当于无向图中的一条边),一个节点可以将收到的数据通过网络链路传输给相连的另一个节点。每条链路的网络总带宽不同(例如某条链路的总带宽为10Gbps)。而每条链路承载的视频传输需要按照占用带宽的多少收取对应网络租用费,每条链路的单位租用费均不同(例如某条链路的租用费为1,000元/Gbps,即1K/Gbps)。某条链路上被占用的带宽总和不得超过该链路的总带宽。
      消费节点:给定的网络结构中有部分网络节点直接连接到小区住户的网络,每个小区住户网络在这个给定的网络结构图中呈现为一个消费节点,不同消费节点的视频带宽消耗需求不同。
视频内容服务器:视频内容服务器存放视频内容(如:电影影片、电视剧等),视频内容服务器的视频数据流可以经由网络节点与链路构成的网络路径流向消费节点,视频内容服务器的输出能力没有上限,可以服务多个消费节点,一个消费节点也可以同时从多台视频内容服务器获取视频流。部署一台视频内容服务器需要费用成本(例如300,000元/台,即300K/台),所有服务器的成本均相同。
       比赛程序内容:请你设计一个程序寻找最优的视频内容服务器部署方案:从网络结构模型中选择一部分网络节点,在其上/附近一对一的部署视频内容服务器,视频内容服务器与对应的这个节点直连,与对应的这个网络节点之间的通信没有带宽限制、也没有通信成本。提供的部署方案需要使得视频流从视频内容服务器经过一些网络节点和链路到达消费节点,并满足所有消费节点的视频带宽消耗需求。

在满足所有消费节点视频带宽消耗需求的前提下,使得耗费的总成本(视频内容服务器部署成本+带宽租用成本)最低。部署方案不仅需要包括部署视频内容服务器的节点位置,而且还要包括每个消费节点与所有视频内容服务器之间的网络路径以及路径上占用的带宽。


比赛胜负规则

若给定的网络拓扑模型不存在满足条件的方案,则输出无解,程序运行时间越短者胜出。若存在满足条件的方案,则成本越低者胜出。若两个方案的成本相同,则程序运行时间越短者胜出。


补充说明:
      1. 两个网络节点之间最多仅存在一条链路,链路上下行方向的网络总带宽相互独立,并且上下行方向的总带宽与网络租用费相同。例如对于网络节点A与B之间的链路,该条链路上的总带宽为10Gbps,单位租用费为1K/Gbps,则表示A->B、B->A两个方向上的网络总带宽分别为10Gbps,并且租用费均为1K/Gbps。如果某条数据流在该链路A->B方向的占用带宽为3Gbps,那么该数据流在该链路的租用费为3K,并且该链路A->B方向的剩余可用带宽为7Gbps。而B->A方向的剩余可用带宽不受该数据流的影响,仍为10Gbps。
      2. 每个网络节点最多仅能连接一个消费节点,每个消费节点仅能连接一个网络节点。消费节点与连接的网络节点之间的链路总带宽无限大,并且网络租用费为零。
      3. 网络节点数量不超过1000个,每个节点的链路数量不超过20条,消费节点的数量不超过500个。
      4. 链路总带宽与网络租用费为[0, 100]的整数,视频内容服务器部署成本与消费节点的视频带宽消耗需求为[0,5000]的整数。
      5. 部署方案中,网络路径上的占用带宽必须为整数。
      6. “满足消费节点的带宽消耗需求”是指输出给消费节点的带宽总和不得小于该消费节点的视频带宽消耗需求。

      7. 每个网络节点上最多仅可部署一台视频内容服务器。


比赛用例示例:

      上图为G省网络拓扑图,黑色圆圈为网络节点,红色圆圈为消费节点,圆圈内的数字为节点编号。节点之间的连线为网络链路。链路上的标记(x, y)中,x表示链路总带宽(单位为Gbps),y表示每Gbps的网络租用费。消费节点相连链路上的数字为消费节点的带宽消耗需求(单位为Gbps)。


      现在假设需要在该网络上部署视频内容服务器,满足所有消费节点的需求。一个成本较低的方案如下图所示,其中绿色圆圈表示已部署的视频内容服务器,通往不同消费节点的网络路径用不同颜色标识,并附带了占用带宽的大小:

但该方案的成本不一定是最低的。因此现在需要参赛者提供的程序能够针对不同的比赛用例,给出成本最低的部署方案。


2 程序输入与输出
输入文件格式:程序输入为一个以空格分隔的文本文件,文件每行以换行符('\n' 或者 '\r\n')为结尾。

文件格式为:
网络节点数量 网络链路数量 消费节点数量
(空行)
视频内容服务器部署成本
(空行)
链路起始节点ID 链路终止节点ID 总带宽大小 单位网络租用费
…………….(如上链路信息若干行)
(空行)
消费节点ID 相连网络节点ID 视频带宽消耗需求
…………….(如上终端用户信息若干行)
(文件结束)
说明:
1. 网络节点ID与消费节点ID均为以0为起始的整数。
2. 文本中出现的所有数值均为大于等于0的整数,数值上限为100000。
输入文件示例(参照第一节中的用例):
28 45 12 // 注:28个网络节点,45条链路,12个消费节点

100 // 注:服务器部署成本为100

0 16 8 2 // 注:链路起始节点为0,链路终止节点为16 ,总带宽为8,单位网络租用费为2
0 26 13 2
0 9 14 2
0 8 36 2
(以下省略若干行网络节点信息)
0 8 40 // 注:消费节点0,相连网络节点ID为8,视频带宽消耗需求为40
1 11 13
2 22 28
3 3 45
4 17 11
5 19 26
6 16 15
7 13 13
8 5 18
9 25 15
10 7 10
11 24 23

输出文件格式
程序输出为一个以空格分隔的文本文件,文件每行以换行符('\n' 或者 '\r\n')为结尾。
文件格式为:
如果不存在满足条件的方案,则输出一行
NA
(文件结束)
如果存在满足条件的方案,则按如下格式输出:
网络路径数量
(空行)
网络节点ID-01 网络节点ID-02 …… 网络节点ID-n 消费节点ID 占用带宽大小
…………….(如上网络路径信息若干行,每条网络路径由若干网络节点构成,路径的起始节点ID-01表示该节点部署了视频内容服务器,终止节点为某个消费节点)
(文件结束)
说明:
1. 网络路径数量不得超过50000条。
2. 单条路径的节点数量不得超过1000个。
3. 不同网络路径可按任意先后顺序输出。
4. 网络节点ID与消费节点ID的数值必须与输入文件相符合,如果ID数值不存在于输入文件中,则将被视为无效结果。
5. 文本文件中出现的所有数值必须为大于等于0的整数,数值大小不得超过100000。
输出文件示例(参照第一节中的用例部署方案):
19 // 注:共输出19条网络路径

0 9 11 1 13 // 注:起始网络节点ID为0,经由ID为9、11等网络节点到达消费节点1,占用带宽为13
0 7 10 10
0 8 0 36
0 6 5 8 13

(以下省略网络路径若干行)

说明:在赛题包中含有用例的txt


3 单个用例的评分机制

有解用例的排名机制
按下面流程对参赛者结果进行排名:
Step1: 对于提交的结果,进行合法性检验(详见题目描述);
Step2: 单个用例的程序运行时间不得超过90s;
若不满足上述的结果则本用例得分为0;
Step3: 计算部署方案的成本,成本越小,排名越优;
Step4: 在成本相同的结果里,用程序运行时间进行排名,时间越短,排名越优。
无解用例的排名机制
按下列流程对参赛者结果进行排名:
Step1: 对于提交的结果,验证是否识别出该用例无解,若无法识别或者算法运行时间超90s,则本用例得分为0;
Step2: 用程序的运行时间进行排名,时间越短,排名越优。
单个用例的评分标准如下:
根据上面排名流程得到的排名,使用标准分计分(排名第一的提交者为100分)。

若所有人均未得到正确结果,则所有人均得分为0。


4 最终得分机制
比赛平台会使用N个测试用例判题,该N个测试用例分为初级、中级、高级三个等级,参赛者对于每个测试用例都会得到一个百分制分数,使用加权平均分(初级权重为0.2,中级权重为0.3,高级权重为0.5)作为该参赛者的最终得分。
补充说明:前期系统会提供练习用例用于判题与排名,4月1日开始提供正式用例。截止初赛结束前,系统将在用例上自动运行选手最后一次提交的代码并进行评分,所得分数为初赛最终成绩。 在比赛初期,比赛平台只提供初级、中级的练习用例,故此时满分为50分,在比赛后期,才会提供高级练习用例(具体时间会在网站公告通知),此时满分才为100。

你可能感兴趣的:(算法,思路,2017,华为软件精英挑战赛)