- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
你给出一个网格(这里是 4x4)。您需要找出从 (0,0) 到 (4,4) 的唯一路径的总数。 main() 为此调用一个函数 pathify。它找到可能的“下一步”并再次调用它。当到达 (4,4) 时 noOfPaths++;应该执行。这不会发生,我找不到问题所在。
import java.util.ArrayList;
public class NoOfPaths {
static int xRows = 4;
static int yColumns = 4;
static int noOfPaths = 0;
/*A robot is located in the upper-left corner of a 4×4 grid.
* The robot can move either up, down, left, or right,
* but cannot go to the same location twice.
* The robot is trying to reach the lower-right corner of the grid.
* Your task is to find out the number of unique ways to reach the destination.
**/
static ArrayList validNeighbours (int x,int y, ArrayList visited) {
ArrayList valid = new ArrayList();
if((x+1 <= xRows) && !visited.contains(((x+1)*10)+y) ) {
valid.add(((x+1)*10)+y);
}
if((x-1 >= 0) && !visited.contains(((x-1)*10)+y) ) {
valid.add(((x-1)*10)+y);
}
if((y+1 <= yColumns) && !visited.contains(x*10+y+1) ) {
valid.add(x*10+y+1);
}
if((y-1 >= 0) && !visited.contains(x*10+y-1) ) {
valid.add(x*10+y-1);
}
return valid;
}
static void pathify(int x,int y, ArrayList alreadyVisited) {
if(x == xRows && y == yColumns) {
noOfPaths++;
} else {
alreadyVisited.add(x*10+y);
ArrayList callAgain = new ArrayList();
callAgain = validNeighbours(x,y,alreadyVisited);
for (int t=0,temp; t<callAgain.size(); t++) {
temp=(int) callAgain.get(t);
pathify(temp/10, temp%10, alreadyVisited);
}
}
}
public static void main(String[] args) {
ArrayList alreadyVisited = new ArrayList();
pathify(0, 0, alreadyVisited);
System.out.println(noOfPaths);
}
}
最佳答案
错误在于您处理alreadyVisited
的方式。第一次调用 pathify
时,此列表将仅包含初始方 block (0,0),这很好。这是代码的重要部分:
for (int t=0,temp; t<callAgain.size(); t++) {
temp=(int) callAgain.get(t);
pathify(temp/10, temp%10, alreadyVisited);
}
您已经找到了初始单元格的邻居。您的代码将选择第一个邻居;然后它将找到从该邻居开始的路径,并且对 pathify
的递归调用会将单元格添加到 alreadyVisited
。
现在,在所有递归调用返回后,您就可以找到从初始单元格的第二个 邻居开始的单元格。但是你有一个问题:alreadyVisited
仍然有它从它找到的从第二个邻居开始的路径收集的所有单元格。 所以你不会找到所有可能的路径开始于第二个邻居;您不会在您之前找到的任何 路径中找到包含任何 单元格的任何路径。这不是您想要的,因为您只想避免访问每个 路径中的同一个单元格——您不想避免访问所有先前路径中的同一个单元格。 (我稍微简化了一点。实际上,问题将开始出现在递归堆栈的更深处,您甚至找不到从第一个邻居开始的所有路径。)
在实现递归算法时,我发现保留由递归调用共享的中间数据结构通常不是一个好主意,递归调用将被这些调用修改。在本例中,这是列表 alreadyVisited
。问题在于,当堆栈深处的调用修改结构时,这会影响更上层的调用,因为它们会在更深层次的调用返回后看到修改,这基本上是它们需要在它们下面更改的数据。 (我不是在谈论用于保存结果列表的集合,如果该列表基本上是只写的。)这里避免它的方法是,而不是添加到 alreadyVisited
,您可以创建此列表的克隆,然后添加到其中。这样,更深的调用可以确保它不会通过更改数据来影响较浅的调用。也就是说,而不是
alreadyVisited.add(x*10+y);
写
alreadyVisited = [make a copy of alreadyVisited];
alreadyVisited.add(x*10+y);
add
将修改一个新列表,而不是其他调用正在使用的列表。 (就个人而言,我会声明一个新变量,例如 newAlreadyVisited
,因为出于可读性原因,我不太喜欢修改参数。)
这看起来效率不高。它肯定会使用更多内存(尽管内存应该很快就能被垃圾回收)。但是尝试在递归调用之间共享数据结构是非常非常难以正确完成的。如果您非常小心地清理更改并将结构恢复到方法开始时的状态,就可以做到这一点。如果结构类似于一棵大树,那么这可能是必要的,使得每次调用都无法复制。但要使事情顺利进行可能需要很多技巧。
编辑: 我测试了它,它似乎可以工作:12 if xRows
=yColumns
=2, 8512 if both are 4 (is对吗?)。另一种方法:我没有复制列表,而是尝试了
alreadyVisited.remove((Object)(x*10+y));
在方法的末尾((Object)
是必需的,这样 Java 就不会认为您在索引处删除),这给了我相同的结果。如果这样做,您将确保 alreadyVisited
在 pathify
返回时与它开始时相同。但我想强调的是,除非您真的知道自己在做什么,否则我不推荐这种“清理”方法。
关于java - 我无法在 java 中修改我的静态变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41584627/
前言: 有时候,一个数据库有多个帐号,包括数据库管理员,开发人员,运维支撑人员等,可能有很多帐号都有比较大的权限,例如DDL操作权限(创建,修改,删除存储过程,创建,修改,删除表等),账户多了,管理
这个问题已经有答案了: Condition variable deadlock (2 个回答) 已关闭 5 年前。 在研究多线程时,我编写了以下代码,但在屏幕上没有观察到输出。我在这里做错了什么?我期
复制代码 代码如下: <IfModule mod_rewrite.c> RewriteEngineOn RewriteBase/ #将www.zzvips.com跳转到www.zzv
复制代码 代码如下: <IfModule mod_rewrite.c> RewriteEngine On RewriteBase / # 把 www.zzvips.com
复制代码 代码如下: Const T_GATEWAY = "1.1.1.1" '网关 Const T_NEWDNS1 = "2.2.2.2" 'DNS1
0. 修改索引 大文本字段支持排序 PUT http://localhost:9200/lrc_blog/_mapping //请求体 { "properties": { "title": { "t
仅 react 当状态发生变化时重新渲染 . 那么为什么我会直接看到我对真实 DOM 所做的更改呢? 我知道我正在修改真实的 DOM,但是当我根本没有改变状态时触发重新渲染的是什么。 import R
Xcode beta 5 推出 @FetchRequest对于 SwiftUI。 我有一个 View ,它有一个 @FetchRequest . NSFetchRequest是在管理器中创建的,该管理
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 7年前关闭。 Improve this questi
我有一个表达式[text][id]应替换为链接 text 解决方案是( id 是整数) $s = preg_replace("/\[([^\]]+)(\]*)\]\[([0-9]+)\]/","$1$
我在 repo 中有一个文件,我不想让任何人更新。 我能做什么? 最佳答案 你想要svn锁:http://www.linxit.de/svnbook/en/1.2/svn.ref.svn.c.lock
说我有项目 list 。我想导出到csv,但在此之前我想做一些计算/修改。 基本上,设置如下所示: PS C:\Files> gci Directory: C:\Files Mode
我有一个非常简单的问题 - 是否可以修改 Java API 的源代码,例如Junit,JABX ? 我知道这似乎是一个非常愚蠢的问题,但它一直困扰着我一段时间。 最佳答案 如果您可以掌握源代码,那么请
我有一个带有变量/列的小标题,其中包括不同形状的小标题列表。我想为其中一个变量中的每个(子)标题添加一个变量/列。 例如此类数据 library("tibble") aaa aaa # A tibb
我有几个菜单,可以在单击时向当前链接添加变量。这是一个例子: 1 2 3 x y z 我的问题是,如果我选择“y”2次,它会添加“&cord=y”2次。相反,我希望它替
我有两个项目:一个服务项目和一个服务安装程序项目。服务项目具有适合我的产品的装配信息。它包括公司信息和正确的服务名称。一旦服务实际安装,所有这些似乎都会被忽略。安装服务时,它使用在服务安装程序的ini
以下代码何时可能产生副作用? @some = map { s/xxx/y/; $_ } @some; perlcritic 将其解释为危险的,因为例如: @other = map { s/xxx/y/
我想知道以下哪种解决方案更好:我想修改一些 .class 文件,我意识到有两种方法可以做到这一点: 反编译.class文件,修改它,最后再次编译。 - 直接用十六进制编辑器修改。 谢谢 最佳答案 在这
这是我的按钮代码 onclick 我希望我的程序等待用户单击一个 JPanel,并且当用户单击 JPanel 时,它应该在控制台上打印其名称。 此按钮代码未显示输出 JPopupMenu popu
我正在使用一个具有“getName()”方法的特定 API。 getName() 返回一个字符串。是否可以修改该字符串? API 中不包含修饰符方法,并且 String getName() 返回的是私
我是一名优秀的程序员,十分优秀!