鱼C论坛

 找回密码
 立即注册
查看: 482|回复: 5

求助大佬:这道题除了穷举和遍历还有其他算法吗。

[复制链接]
发表于 2023-11-7 19:22:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
在理想情况下(无障碍物,不考虑碰撞),4辆小车(a, b, c, d)同时出发,要分别到达4个指定的位置的车库(A, B, C, D)(一个车库只能停一辆车),假设全部小车进库的时间是T(即最后一辆小车入库的时间),编程求出T的最小值。小车入库的时间如下表所示。
表1 小车入库时间表(单位:分钟)
        A        B        C        D
a        4        8        7        15
b        7        9        17        14
c        6        9        12        8
d        6        7        14        6
答案:T=8
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-7 19:22:58 | 显示全部楼层
这是一个典型的旅行商问题(TSP),可以使用启发式算法来解决。其中最常用的是遗传算法(Genetic Algorithm)和模拟退火算法(Simulated Annealing)。这些算法可以帮助找到较优解,避免了穷举和遍历的低效率。在这个问题中,可以将每辆车看作一个旅行商,每个车库看作一个城市,然后使用启发式算法来找到最短路径,即最小的T值。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2023-11-7 19:23:58 | 显示全部楼层
小车最短时间问题

这个问题可以通过贪心算法来解决。我们可以对每个车库的时间进行排序,然后让每辆车按顺序选择最早可用的车库。

下面是C++代码的一个例子:
  1. #include <iostream>
  2. #include <vector>
  3. #include <algorithm>
  4. int main()
  5. {
  6.     std::vector<std::vector<int>> times = {
  7.         {4, 8, 7, 15},
  8.         {7, 9, 17, 14},
  9.         {6, 9, 12, 8},
  10.         {6, 7, 14, 6}
  11.     };
  12.     for (auto& t : times) {
  13.         std::sort(t.begin(), t.end());
  14.     }
  15.     std::vector<int> cars = {0, 1, 2, 3}; // 车辆编号
  16.     int min_time = 0;
  17.     do {
  18.         int current_time = 0;
  19.         for (int i = 0; i < 4; ++i) {
  20.             current_time += times[i][cars[i]];
  21.         }
  22.         min_time = std::min(min_time, current_time);
  23.     } while (std::next_permutation(cars.begin(), cars.end()));
  24.     std::cout << "最小时间为:" << min_time << std::endl;
  25.     return 0;
  26. }
复制代码

在这个程序中,我们首先对每个小车的到达时间进行排序。然后使用了std::next_permutation对所有可能的车辆到达顺序进行遍历,计算每种到达顺序下的总时间,并找出最小值。

球一个最佳答案谢谢啦!这对我非常重要!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2023-11-7 19:58:56 | 显示全部楼层
Mike_python小 发表于 2023-11-7 19:23
小车最短时间问题

这个问题可以通过贪心算法来解决。我们可以对每个车库的时间进行排序,然后让每辆车按顺 ...

这个代码跑出来怎么是0,这个代码好像求的是总时间最小,题目的T是最后一辆小车入库的时间,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-11-7 20:00:44 | 显示全部楼层
isdkz 发表于 2023-11-7 19:22
这是一个典型的旅行商问题(TSP),可以使用启发式算法来解决。其中最常用的是遗传算法(Genetic Algorithm ...

用最短路径来做求出来的是总时间最小,但这道题求的是T是最后一辆小车入库的时间,车辆都是同时出发
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-11-9 18:36:44 | 显示全部楼层
没人吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-28 01:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表