当前位置: 首页 > news >正文

郑州大型网站建设电话乌海品牌网站建设

郑州大型网站建设电话,乌海品牌网站建设,什么是主页,大学生个人简历word免费模板前言 本次主要是记录自己第一次参加华为软件挑战赛的经历。第一次参加比赛还是缺少经验#xff0c;训练赛中拿到赛区的20多名#xff0c;最后在正式赛中被反超了#xff0c;只拿了40多名#xff0c;实在是感到可惜。 题目#xff1a;本次题目是一个智慧港口的问题。10个机…前言 本次主要是记录自己第一次参加华为软件挑战赛的经历。第一次参加比赛还是缺少经验训练赛中拿到赛区的20多名最后在正式赛中被反超了只拿了40多名实在是感到可惜。 题目本次题目是一个智慧港口的问题。10个机器人10个泊位5个轮船运货轮船到虚拟点之后就可以产生价值。目标最大化价值。 处理思维 在高层思维上本次的思维比较简单就是让前几任在15000帧率里面都拿到货物轮船拼命拿货。 算法要求 巡路算法本次大概有两个考虑由于机器人只能走曼哈顿距离所以考虑就有A和BFS算法。最后尝试之后发现A的速度比较快但是由于其引导函数一直找不到合适的所以求得的路径一直就不是最优的曼哈顿距离函数做引导函数不科学最后还是选择了最朴素的广度优先搜索算法对其进行改进基本上满足了帧率要求。策略5个轮船分别分到10个一近一远的码头这样子可以保证每个机器人的来回运输时间差不多基本可以达到最优效果。在最后一次来码头搬货的时候在第二个码头的时候就要压缩轮船的离开时间为最后的5帧率自己返回码头的时间的将时间完全利用上。机器人也是在分配码头的时候分配一个最近且可达的码头。碰撞挽救由于地图的各种情况不可避免会出现碰撞和异常问题个人在这个方面做的最差不然也就进决赛了。大概做了下面几个策 单通道内出现碰撞大致就是倒车和目标交货策略。两个机器人发生碰撞直接进行目标交换然后pop出第一个路径即可。倒车也是种更好选择非单管道碰撞可以选择在碰撞时候选择绕行。 # 机器人控制函数 void control_robots() {std::vectorstd::pairint, int robot_next; // 最新机器人坐标for (int i 0; i 10; i) {robot_next.push_back({robot[i].x, robot[i].y});}for (int robot_id : robot_list) {//改成先判断机器人是否存在异常if(robot[robot_id].status 0){if (robot[robot_id].goods 1)//机器人携带货物异常{robot[robot_id].target[0] -1;robot[robot_id].target[1] -1; robot[robot_id].berth -1;robot[robot_id].ops.clear();search_berth(robot_id, best_robot_map[robot_id].second);}else //机器人没有携带货物发生异常则可以搜索货物{ robot[robot_id].target[0] -1;robot[robot_id].target[1] -1; robot[robot_id].ops.clear();search_goods( robot_id, 100, 1);}}//如果机器人有目标的话就执行下面的操作。有目标但是不一定有货物。可能是泊位目标也可能是货物目标if (robot[robot_id].target[0] ! -1) { //有货物但是没有泊位就搜匹配的泊位路径if (robot[robot_id].goods 1 robot[robot_id].berth -1) { search_berth(robot_id, best_robot_map[robot_id].second); //search_berth()函数前面是机器人id后面是泊位id}//前面不执行的话说明就是机器人是有目标身上没货其实就是有货物目标但是没有拿到那么传的就是机器人目标auto target_i robot[robot_id].target; //不管如何都要将机器人的目标传出去前面如果执行目标位置就是泊位如果不执行目标位置就是原来的货物if (!robot[robot_id].ops.empty()) {auto DOA robot[robot_id].ops.front();auto temp_next direction(robot[robot_id].x, robot[robot_id].y, DOA);if (std::find(robot_next.begin(), robot_next.end(), temp_next) robot_next.end()) {//如果当前机器人的下一个位置在10个机器人机器人坐标里面都没有找到则说明没有发生碰撞if (robot[robot_id].status 1) //如果机器人status正常处于正常状态那么就移动机器人{robot_next.push_back(temp_next);robot[robot_id].ops.erase(robot[robot_id].ops.begin()); // 移除已执行的操作printf(move %d %d\n, robot_id, DOA);}}}//机器人到达指定位置if (robot[robot_id].xtarget_i[0] robot[robot_id].y target_i[1] robot[robot_id].goods 0) { printf(get %d\n, robot_id);gds[target_i[0]][target_i[1]].reset();}//机器人到达了指定码头if (robot[robot_id].goods 1 robot[robot_id].xberth[best_robot_map[robot_id].second].x robot[robot_id].y berth[best_robot_map[robot_id].second].y) {printf(pull %d\n, robot_id);berth[best_robot_map[robot_id].second].goods 1;robot[robot_id].target[0] -1;robot[robot_id].target[1] -1; // 重置目标robot[robot_id].berth -1;search_goods( robot_id, 100, 1); //一放下货物就开始搜}}else //如果机器人没有目标的话就搜索货物因为没有目标的情况只有一种就是在码头放完货的时候search_goods( robot_id, 100, 1);} } #轮船控制函数 void control_robots() {std::vectorstd::pairint, int robot_next; // 最新机器人坐标for (int i 0; i 10; i) {robot_next.push_back({robot[i].x, robot[i].y});}for (int robot_id : robot_list) {//改成先判断机器人是否存在异常if(robot[robot_id].status 0){if (robot[robot_id].goods 1)//机器人携带货物异常{robot[robot_id].target[0] -1;robot[robot_id].target[1] -1; robot[robot_id].berth -1;robot[robot_id].ops.clear();search_berth(robot_id, best_robot_map[robot_id].second);}else //机器人没有携带货物发生异常则可以搜索货物{ robot[robot_id].target[0] -1;robot[robot_id].target[1] -1; robot[robot_id].ops.clear();search_goods( robot_id, 100, 1);}}//如果机器人有目标的话就执行下面的操作。有目标但是不一定有货物。可能是泊位目标也可能是货物目标if (robot[robot_id].target[0] ! -1) { //有货物但是没有泊位就搜匹配的泊位路径if (robot[robot_id].goods 1 robot[robot_id].berth -1) { search_berth(robot_id, best_robot_map[robot_id].second); //search_berth()函数前面是机器人id后面是泊位id}//前面不执行的话说明就是机器人是有目标身上没货其实就是有货物目标但是没有拿到那么传的就是机器人目标auto target_i robot[robot_id].target; //不管如何都要将机器人的目标传出去前面如果执行目标位置就是泊位如果不执行目标位置就是原来的货物if (!robot[robot_id].ops.empty()) {auto DOA robot[robot_id].ops.front();auto temp_next direction(robot[robot_id].x, robot[robot_id].y, DOA);if (std::find(robot_next.begin(), robot_next.end(), temp_next) robot_next.end()) {//如果当前机器人的下一个位置在10个机器人机器人坐标里面都没有找到则说明没有发生碰撞if (robot[robot_id].status 1) //如果机器人status正常处于正常状态那么就移动机器人{robot_next.push_back(temp_next);robot[robot_id].ops.erase(robot[robot_id].ops.begin()); // 移除已执行的操作printf(move %d %d\n, robot_id, DOA);}}}//机器人到达指定位置if (robot[robot_id].xtarget_i[0] robot[robot_id].y target_i[1] robot[robot_id].goods 0) { printf(get %d\n, robot_id);gds[target_i[0]][target_i[1]].reset();}//机器人到达了指定码头if (robot[robot_id].goods 1 robot[robot_id].xberth[best_robot_map[robot_id].second].x robot[robot_id].y berth[best_robot_map[robot_id].second].y) {printf(pull %d\n, robot_id);berth[best_robot_map[robot_id].second].goods 1;robot[robot_id].target[0] -1;robot[robot_id].target[1] -1; // 重置目标robot[robot_id].berth -1;search_goods( robot_id, 100, 1); //一放下货物就开始搜}}else //如果机器人没有目标的话就搜索货物因为没有目标的情况只有一种就是在码头放完货的时候search_goods( robot_id, 100, 1);} } 写在最后由于代码较长版幅有限所以就把资源放到个人哪里明年再战。 2024年3月25日于深圳大学
http://www.zqtcl.cn/news/403535/

相关文章:

  • 宿迁网站建设要多少钱高密市住房和城乡建设局网站
  • 咸阳网站建设公司哪家好wordpress访客ip记录
  • 厦门建设银行网站那个网站做效果图电脑配置
  • 人才网站建设医院网站建设的好处
  • 房屋装修网站模板html5做网站
  • 网站建设需要的硬件网站建设知名公司排名
  • 绥化网站建设私自搭建vps犯法吗
  • 建设专业网站哪家比较好小程序源码是什么意思
  • 网站设计一般包括什么给公司做网站数据分析
  • 网站根目录在哪里1024cctvcom戊人影祝
  • wordpress转发微信南宁seo企业优化
  • 红旗渠建设集团网站昭通网络推广
  • 海陵区建设局网站计算机网站建设考试试卷
  • 佛山做网站3lue网站开发招标网
  • 粘贴以下代码到网站首页代码的与标签之间渭南软件开发
  • 企业网站建设必要性上海网站建设报价表
  • 陕西省建设厅申报网站一个主体如何添加网站
  • 做网站业务员提成几个点wordpress 地图导航代码
  • 软件下载网站排行住房和城乡建设部办公厅网站
  • 贵阳网站建设需要多少钱百度资源搜索平台
  • 做安全防护信息的网站wordpress初始密码
  • 广东企业网站seo哪里好微信公众号怎么创建文章
  • 建行网站登录不了wordpress好主题
  • 南屏网站建设湖北省建设厅的网站
  • 有没有做花卉种子的网站啊正规网站建设服务
  • 长沙网站建设公司招聘那个建设网站好
  • 网站开发视频下载网站优化关键词排名自己怎么做
  • 网站建设 流程咸宁网站建设哪家好
  • 建站公司兴田德润实惠钦州建设局网站
  • 高新区免费网站建设旅游网站开发设计与实现