2019华为软件挑战赛初赛代码开源分享


本项目是华为2019年软件精英挑战赛的初赛题目的实现,初赛排名西北赛区 41 名
项目地址:https://github.com/WFrame0224/SDK_python



1. 运行说明

  • 使用语言 python 3.5
  • 采用的是 Ubuntu 18.04.2
  • 目录结构如下所示:
    目录结构
  • 运行时,执行下面任意一条命令即可:
    • python CodeCraft-2019.py ../config/car.txt ../config/road.txt ../config/cross.txt ../config/answer.txt
    • python dispatcher.py

2. 程序数据结构

数据结构
上图所示为代码所用的数据结构

3. 程序文档说明

3.1 程序函数说明

  • strListToIntList(srcStr) strList转换为intList,方便后面的操作
  • loadData(filePath) 用于载入数据的函数生成器,调用一次返回一行数据
  • loadRoadData(road_path) 读取道路的数据
  • loadCarData(car_path) 用于载入car的数据建立有序的Cars二维列表
  • loadCrossData(cross_path) 此函数用于读取路口信息,返回
  • getRoadId(head, tail, Crosses) 函数用于返回两个路口连接的道路标号
  • creatGraph() 函数用于构建一基本路口道路有向图
  • driveCar2() 此函数是按照一定的发车方式,上路进行奔跑

3.2 程序逻辑简要说明

  • :程序并未实现调度器,或者是判题器,实际上式找了捷径,优化发车策略(调参)进行最大程度地避免死锁现象的发生

  • 程序主要执行逻辑如下图所示:

    在这里插入图片描述

:逻辑中,车辆的预处理非常重要,对应于后面的发车策略

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值