- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有二维 boolean 数组 a,它应该代表不同人之间的关系/友谊。每个人都通过他们的 id(数组索引)来识别,如果例如a[1][0] 为 true,则 1 和 0 是 friend 。如果 2 个人是 friend ,他们的“ friend 距离”就是 1。人们也可以通过其他人成为 friend ,例如:如果a[1][0] = true,a[2][0] = true,a[2][1] = false,则人员1和人员2不是直接 friend ,而是因为人员1是人员0的 friend ,而人 0 是人 2 的 friend ,人 1 和人 2 是距离为 2 的 friend 。现在我想递归地确定 2 个人是否是给定距离内的 friend ,或者是否不是。我已经写了这段代码:
public static boolean areFriends(int id0, int id1, int e) {
if (e <= 0) {
return false;
}
if (array[id0][id1]) {
return true;
}
for (int i = 0; i < array.length; i++) {
if (array[id0][i]){
(areFriends(i, id1, --e);
}
}
return false;
}
}
代码至少应该做的是遍历 id0s friend 列表,并检查每个数组条目,如果 id0 和检查的人 idx 是 friend 。如果是,则重复该方法,用 idx 替换 id0s 位置,并 --e。因此,再次检查所有 idx 的关系,如果 idx 是另一个人的 friend ,则整个循环会重复,直到“ friend 距离”e 太高(因此不存在间接友谊)或找到间接友谊。 p>
但显然这段代码并没有完全做到这一点,所以我会对我做错了什么或如何修复错误的任何提示有所帮助。
最佳答案
最好将数据表示为图,然后使用 Dijikstra 算法来查找两个节点之间的路径。事实上,每个人都由一个节点表示,两个节点之间的弧调节了友谊关系。
对于您的数据模块,我建议作为解决方案:
public static boolean areFriends(boolean friends[][], int id1, int id2, int distance) {
if (friends[id1][id2]) {
return true;
}
if (distance == 0) {
return freinds[id1][id2];
}
for (int i = 0; i < friends[id1].length; i++) {
if (i != id1 && friends[id1][i] && areFriends(friends, i, id2, distance - 1)) {
return true;
}
}
return false;
}
关于java - 递归查找 "indirect relationships",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58904939/
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
我意识到这个问题已经提出,但是由于与我在类似问题上看到的原因不同,导致了我的原因,所以这是我的设置。 我有2个C#项目A和B,项目B引用了一个第三方库Indirect。 A将调用在B中定义的静态方法,
我想要实现的是,如果 AB 列中的一个单元格等于"is"并且 AC 列中的一个单元格是空白的,那么一定范围的单元格将被格式化。目前,该规则没有格式化它应该格式化的单元格。我将此代码基于我正在使用的另一
我正在尝试动态计算电子表格的每周周数,因为每周都会在标题中的日期将新数据添加到列中。我的数据如下所示: Name WoW 9/27/2018 10/4/2018 10/11/2018
我已经四处寻找如何对整列(在另一张纸上)使用间接命令,但 react 有限 我见过它必须是这样的 =SUMIF(Site!$A:$A,D11,indirect("Site!$F",Row($F)) 我
我在下面有一个 INDIRECT 公式,问题是当我将“F3”单元格拖动到填充单元格时,它似乎不是相对的。 =INDIRECT("'Sheet 2'!F3") 如何使“F3”相对? 谢谢!! 最佳答案
我正在寻找一种方法,使间接公式忽略错误并打印 0。我让它以一种迂回的方式工作,但希望它更整洁。 我有一个INDIRECT公式来从单独的工作表加载单元格 =INDIRECT("'Invoice (2)'
我有几个单元格计算来自多个工作表的单个单元格的总数,在这种情况下,来自 Week 中的每个工作表的“Y3”,其中 n 是从 1 到 10 的整数: =SUMPRODUCT(COUNTIF(INDIRE
我正在尝试使用自定义创建的引用字符串从表中引用总计。这基本上可以正常工作,直到我在以不同语言安装的 excel 中打开电子表格。所以我所拥有的是: INDIRECT("Attendees[[#Tota
我在这个示例中有 4 张纸,每张纸都有一个 A1 中的值,如下所示: Sheet1 - A1=18 Sheet2 - A1=15 Sheet3 - A1=197 Sheet4 - A1=534 然后在
我不理解这个错误(C2100:非法间接)。我标记了三个实例——都在底部附近。我在网上看过,我知道这与我的指示有关,但在 8 小时后,我完全迷路了。这里可能还有其他一些错误,但我什至无法分辨,因为我无法
我想使用 Excel 中的间接函数引用另一个工作簿,假设其名称为“My workbook.xlsm”。 但是,“我的工作簿”文件名之前或之后可以有任何其他字符串/字符。 假设我正在尝试查找“查找值”
所以我有二维 boolean 数组 a,它应该代表不同人之间的关系/友谊。每个人都通过他们的 id(数组索引)来识别,如果例如a[1][0] 为 true,则 1 和 0 是 friend 。如果 2
据我了解,如果 H4 中的值为 5,则有两种方法可以引用该单元格: =H4 和 =INDIRECT("H4") 不过,我无法找到一种方法来使其与名称引用一起工作。例如,如果我想计算一些数据的总和,我可
我正在尝试动态分配一个连续的内存块,存储一些整数值并显示它。 #include #include void main() { int i; int *ptr; ptr=
我正在尝试解决命题逻辑中的一个问题,我认为我从未在任何地方看到过这个问题。我将它张贴在这里,看看是否有人有一个有希望的标准解决方案。 问题:给定一个命题可满足逻辑公式F和一个出现在F中的命题p,判断是
p是一个指向数组arr的指针,我们可以通过*p获取数组arr ,但是为什么用*p[2]获取不到第二个元素呢? 会报错: invalid indirect of p[1] (type int) 以下代码
看各种pages in the Android docs ,其中一些列出了“已知的间接子类”。这是什么意思? 最佳答案 对于接口(interface),它是实现该接口(interface)的类的列表。
我目前正在使用公式 =匹配(A2,间接(Q20):间接(Q22),0)其中 A2 包含要在一个范围内搜索的项目。范围是动态的,Q20 的起点为 =地址(Q17,3,4) Q22 持有 =地址(Q18,
我需要使用 Excel Indirect() 函数来引用非连续范围。这个( How to define a non continuous range in COUNTIF )答案给出了一个例子。 总之
我是一名优秀的程序员,十分优秀!