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

电子商务网站开发进什么科目top的域名网站

电子商务网站开发进什么科目,top的域名网站,网络营销是什么经营模式,微信开放平台介绍前言 本次主要是记录自己第一次参加华为软件挑战赛的经历。第一次参加比赛还是缺少经验#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.eeditor.cn/news/125129/

相关文章:

  • 顺丰物流网站建设策划书卢松松网站源码
  • 学校网站设计的目的上海哪些做网站
  • dedecms企业网站模板免费下载wordpress 公共库
  • 台州手机网站建设手机网站设计制作公司
  • 网络公司做的网站根目录在哪白沟网站开发
  • 手机软件下载网站推荐宠物网站建设论文
  • 商务网站规划与建设课设的项目需求免费网络电话无限打
  • 网站建设方式与信息化南阳网站建设电话
  • 深圳做网站de自己做网站软件
  • 做设计外包的网站遵义网站建设公司排名
  • 想找一家公司设计网站林州建筑网
  • 昆明网站建设哪个公司好网站建设的案例教程
  • 做一个网站需要服务器吗重庆市
  • 启东市住房建设局网站wordpress更改轮播图
  • 做第三方库个人网站保定建站服务
  • 标准物质网站建设查网站服务器速度
  • 紫金网站建设公司东莞公司注册地址
  • 商城建站模板如何提高网站在百度的排名
  • 包头市做网站哪个设计君网站
  • 网络营销的概念与含义seo代运营公司
  • 橙色企业网站模板备案号怎么放置到网站
  • 织梦个人网站模板花店营销策略超市门户网站建设
  • 做内贸的什么网站效果好深圳工程造价信息网官网
  • 育贤网站建设做网站用什么做
  • 博客网站代码北京商城网站设计
  • 贵阳网站建设公司深圳企业网站建设费用明细
  • seo综合查询爱站杭州注册公司流程是怎样的
  • 随州做网站生意怎么样内网安装wordpress
  • 梧州网站建设贝尔利怎么找网站站长
  • php网站截图韩国出线形势