- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试解决这个问题,O(N^2) 的解决方案很简单,O(N) 是可能的,但我想不出如何解决。这是问题:
史蒂文的世界里有 N 个城市和 N 条有向道路。城市编号从 0 到 N - 1。史蒂文可以从城市 i 到城市 (i + 1) % N, ( 0-> 1 -> 2 -> .... -> N - 1 -> 0) .
史蒂文想驾车环游世界。他的汽车油箱的容量是 C 加仑。他可以在城市 i 的起点使用 a[i] 加仑,而汽车从城市 i 行驶到 (i + 1) % N 需要 b[i] 加仑。
史蒂文可以从多少个城市开始他的汽车,这样他就可以环游世界并到达他开始的同一个城市?
注意
油箱最初是空的。
输入格式第一行包含两个整数(以空格分隔):城市编号 N 和容量 C。第二行包含 N 个以空格分隔的整数:a[0]、a[1]、...、a[N - 1]。第三行包含 N 个以空格分隔的整数:b[0]、b[1]、...、b[N - 1]。
输出格式可以选择作为起始城市的城市数量。
示例输入
3 3
3 1 2
2 2 2
示例输出
2
说明
史蒂文从 0 号城市出发,为他的汽车加满 3 加仑燃油,并使用 2 加仑燃油前往城市 1。他的油箱现在有 1 加仑燃油。在城市 1 加油 1 加仑燃料后,他使用 2 加仑燃料前往城市 2。他的油箱现在是空的。在城市 2 加油 2 加仑燃料后,他又使用 2 加仑燃料返回城市 0。
这是第二种可能的解决方案。史蒂文从 2 号城市出发,给他的车加满 2 加仑汽油,然后前往 0 号城市。从城市 0 补充了 3 加仑的燃料后,他前往城市 1,并耗尽了 2 加仑的燃料。他的油箱现在有 1 加仑的油。然后,他可以在城市 1 加满 1 加仑燃油,然后将汽车的燃油增加到 2 加仑,然后前往城市 2。
但是,史蒂文不能从城市 1 出发,因为他只得到 1 加仑的燃料,但前往城市 2 需要 2 加仑。
因此答案 2。
现在我知道这个算法可以在 O(N) 的时间复杂度内解决,我无法解决,猜测它可以使用动态规划解决,请帮助我获得如何将其分解为子问题的线索。
最佳答案
我已经制定了一个应该可以解决问题的算法,它为您的案例输出 2,但必须在其他测试用例上进行测试。我不确定它是否正确。我的主要想法是,如果您可以从一个点开始进行迭代,那么您可以根据需要进行迭代,反之亦然。如果你做不到一个以上,你连一个都做不到。
#include <algorithm>
#include <iostream>
using namespace std;
#define PROB_SIZE 3
int n = PROB_SIZE, c = 3;
int a[PROB_SIZE] = {3, 1, 2}; // available
int b[PROB_SIZE] = {2, 2, 2}; // used
int d[PROB_SIZE];
int dmin[PROB_SIZE];
int main()
{
//The fuel used in the trip to next node (amount put in minus the amount consumed in one trip).
for (int i = 0; i < n; i++) {
d[i] = a[i] - b[i];
}
//The fuel that i need to start a trip in this point and reach point 0.
dmin[n - 1] = d[n - 1];
for (int i = n - 2; i >= 0; i--) {
dmin[i] = min(d[i], d[i] + dmin[i + 1]);
}
//The second loop to be sure i cover a whole loop from any point.
dmin[n - 1] = min(d[n - 1], d[n - 1] + dmin[0]);
for (int i = n - 2; i >= 0; i--) {
dmin[i] = min(d[i], d[i] + dmin[i + 1]);
}
//If for any point i need to have more fuel than i can carry then the trip is impossible for all points.
for (int i = 0; i < n; i++) {
if ((-dmin[i] + a[i]) > c) {
cout << 0 << endl;
return 0;
}
}
int cnt = 0;
//Any point that i need to have 0 fuel to reach point 0 making at least one round trip is a good starting point.
for (int i = 0; i < n; i++) {
if (dmin[i] >= 0) {
cnt++;
}
}
cout << cnt << endl;
}
关于algorithm - 动态规划 : Find possible ways to reach destination,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24408371/
我正在使用底部导航。 在切换画面中,还有一个打开dialog fragment的功能。 为此我还使用了导航。 这是因为,一旦此dialog 完成,data 必须传送到打开该对话框的屏幕。 为此我使用了
我一般是导航图和导航组件的新手,我正在尝试将数据从位于“PrivSectionFragment”中的回收器 View 传递到“PrivSectionDetailFragment”。不幸的是,每当我运行
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我有一个案例需要将图像存储在不同的目录中。所以我将 multer 设置为。 app.use(multer({ dest: path.join(__dirname, '`public/ass
我在我的应用程序中使用了导航组件。我把我的应用程序上传到firebase进行测试。应用程序在大多数设备中正常工作,但在某些设备中应用程序崩溃并显示此图像中的错误。。这是我的导航文件代码。为什么会这样呢
有人在为 appflow 调用 update_flow 时遇到此错误吗? errorMessage": "调用 UpdateFlow 操作时发生错误 (ValidationException):更新流
我为 RSocket 消息写了一个小演示 问题是我无法访问 Rsocket端点, 我从服务器收到以下异常: 客户端: 配置: @Bean RSocket rSocket() { return
当我尝试在 viewpager 中从一个 Fragment 导航到另一个 Fragment 时,我遇到了 Android Navigation Architecture 组件的问题,我收到此错误: j
我正在尝试使用 travis-ci.org 实现持续集成。 这是我当前的 .travis.yml 配置: language: swift osx_image: xcode8.3.3 xcode_pro
当发生配置更改并因此重新创建我的 Activity 和 Fragment 时,我的导航 Graph 范围内的 ViewModel 不可用,而 Fragments 已经被再次创建。 似乎在 navGra
所以我使用的是Django 4.2,它通过Django-JET-REBOOT Fork与Django-JET管理包一起使用;它通过良好的功能和用户体验增强了管理。。每次我将我的应用程序部署到生产环境中
我正在完成我的 CISCO C 类(class),我对以下函数有疑问。 谁能给我解释一下这个函数的逻辑,尤其是这里 --destination 的用法? char *mystrcat(char *de
题目地址:https://leetcode-cn.com/problems/destination-city/ 题目描述 给你一份旅游线路图,该线路图中的旅行线路用数组 paths 表示,其中 p
尝试在服务器上运行应用程序时,我的集成机器人提示... xcodebuild: error: No destinations were specified with the -destination
我正在使用下面的 Java 代码进行 SAP 连接,但我不知道要在 getDestination() 方法中放入什么内容。请指导我如何找到目的地的值(value)或投入什么? createDesti
当绘制路径然后使用 globalCompositeOperation = "destination-out" 绘制完全相同的路径时,如下所示: function drawPath(ctx){ ct
我正在尝试创建径向进度 View 。 Canvas 中的第二条弧应该只清除 Canvas 的一小部分,但它却将其全部清除。 我用过: this.ctx.globalCompositeOperation
我正在从 jboss 5 迁移到 wildfly 12。我陷入了一个异常(exception)我正在java 8中使用wildfly 12和jndi进行ejb(3.1)调用我已经在 Wildfly 控
我想向当前导航图注入(inject)一个新的目的地。 我注意到 NavGraph 有一个方法 void addDestination(@NonNull NavDestination node) 但我找
我有一系列数据在书中的每个工作表中处于相同位置,并且将始终处于该位置。运行宏时,应将数据复制并添加到报告表中。我有那部分工作,但我需要使用特殊粘贴: .PasteSpecial xlPasteValu
我是一名优秀的程序员,十分优秀!