一招解决路径404问题

在第5节中,我们请求转发使用的路径是/servlet2

req.getRequestDispatcher("/servlet2").forward(req, resp);

而我们重定向使用的路径是/web-demo3/servlet2

resp.sendRedirect("/web-demo3/servlet2");

可以看到,有时候我们需要加上虚拟根目录/web-demo3,有时候却不需要,要怎么区分呢?

这里可以看这个请求的使用对象是谁,如果是服务器,我们就不用加虚拟根目录,而如果是浏览器,就得加上虚拟根目录

比如,请求转发是在服务器内部进行的,所以它不需要加虚拟根目录。

然而,重定向是告诉浏览器访问给定链接的,使用的对象是浏览器,所以要加根目录。

表单的提交action发的请求也是一样,它的使用对象是浏览器,所以要加虚拟根目录。

同样,超链接也是从浏览器发送的,所以要加虚拟根目录。

还有一个问题:/web-demo3是虚拟根目录,它的名字是随时可以替换的,所以我们不应该把它写死

可以使用

String contextPath = req.getContextPath()

获取虚拟根目录

然后,拼接一下就可以

resp.sendRedirect(contextPath + "/servlet2");
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
扫描法是一种贪心算法,用于解决路径优化问题。它的基本思想是从一个起点开始,每次选择离当前点最近的未访问过的点作为下一个点,直到所有点都被访问过为止,形成一条路径。这种方法可以得到一条较短的路径,但并不能保证是最优解。 扫描法解决路径优化问题的具体步骤如下: 1. 根据输入的点坐标计算每两个点之间的距离,并保存在一个距离矩阵中。 2. 初始化路径和已经访问的点。起点可以是任意一个点,这里假定起点是第一个点。 3. 从起点开始,每次选择距离当前点最近的未访问过的点作为下一个点,并将该点加入路径中。同时将该点标记为已访问。 4. 重复步骤 3,直到所有点都被访问过为止。此时得到的路径即为最优路径。 需要注意的是,扫描法得到的路径并不一定是最优解,因为它只考虑了当前点和下一个点之间的距离,并没有考虑整个路径的总长度。因此,扫描法通常被用于快速计算一个近似最优解,而不是精确解。 下面是一个使用扫描法解决路径优化问题的 Python 代码示例: ```python import math def scan_tsp(points): # 计算所有点两两之间的距离 n = len(points) dist = [[0] * n for i in range(n)] for i in range(n): for j in range(i + 1, n): dist[i][j] = dist[j][i] = math.sqrt((points[i][0] - points[j][0]) ** 2 + (points[i][1] - points[j][1]) ** 2) # 初始化路径和已经访问的点 path = [0] visited = [False] * n visited[0] = True # 扫描法核心部分 for i in range(n - 1): min_dist = float('inf') min_index = -1 for j in range(n): if not visited[j] and dist[path[-1]][j] < min_dist: min_dist = dist[path[-1]][j] min_index = j path.append(min_index) visited[min_index] = True # 计算路径长度 total_dist = 0 for i in range(n): total_dist += dist[path[i]][path[(i + 1) % n]] # 返回最优路径路径长度 return path, total_dist ``` 使用方法: ```python points = [(0, 0), (1, 1), (2, 2), (3, 3), (4, 4)] path, total_dist = scan_tsp(points) print(path) print(total_dist) ``` 输出结果: ``` [0, 1, 2, 3, 4] 5.656854249492381 ``` 其中,`points` 是一个包含所有点的二元组列表,每个二元组表示一个点的坐标。`path` 是计算出的最优路径,`total_dist` 是该路径的总长度。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值