郑州大型网站建设电话,乌海品牌网站建设,什么是主页,大学生个人简历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日于深圳大学