- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在编写一个 boggle 求解器,但我不知道我的编码哪里出错了。这是我目前所拥有的:
public class Boggle {
char[][] letters;
ArrayList <String> wordsPossible;
boolean[][] lettersUsed;
ArrayList<String> wordsMade = new ArrayList<String>();
public static void main(String[] args) {
Boggle boggle = new Boggle();
boggle.findWords();
}
public Boggle(){
letters = new char[4][4];
letters[0][0] = 'a';
letters[0][1] = 'd';
letters[0][2] = 'e';
letters[0][3] = 'h';
letters[1][0] = 's';
letters[1][1] = 't';
letters[1][2] = 'i';
letters[1][3] = 'p';
letters[2][0] = 's';
letters[2][1] = 'k';
letters[2][2] = 'c';
letters[2][3] = 'e';
letters[3][0] = 'u';
letters[3][1] = 'f';
letters[3][2] = 'r';
letters[3][3] = 'o';
Scanner scanner = null;
try {
scanner = new Scanner(new File("brit-a-z.txt"));
} catch (FileNotFoundException ex) {
Logger.getLogger(Boggle.class.getName()).log(Level.SEVERE, null, ex);
}
wordsPossible = new ArrayList<String>();
while(scanner.hasNext()){
String str = scanner.nextLine();
wordsPossible.add(str);
}
lettersUsed = new boolean[4][4];
}
public void findWords(){
for(int i=0; i<letters.length; i++){
for(int j=0; j<letters[i].length; j++){
//findWords(jLabels[i][j].getText(), i, j, labelsUsed);
findWords(Character.toString(letters[i][j]), i, j, lettersUsed);
System.out.println("Done");
}
}
for(int i=0; i<wordsMade.size(); i++){
System.out.println(wordsMade.get(i));
}
}
public void findWords(String word, int iLoc, int jLoc, boolean[][] lettersUsed){
if(iLoc < 0 || iLoc >= 4 || jLoc < 0 || jLoc >= 4){
return;
}
if(lettersUsed[iLoc][jLoc] == true){
return;
}
word += letters[iLoc][jLoc];
lettersUsed[iLoc][jLoc] = true;
if(word.length() >= 3 && wordsPossible.contains(word)){
System.out.println(word);
wordsMade.add(word);
}
findWords(word, iLoc-1, jLoc, lettersUsed);
findWords(word, iLoc+1, jLoc, lettersUsed);
findWords(word, iLoc, jLoc-1, lettersUsed);
findWords(word, iLoc, jLoc+1, lettersUsed);
findWords(word, iLoc-1, jLoc+1, lettersUsed);
findWords(word, iLoc-1, jLoc-1, lettersUsed);
findWords(word, iLoc+1, jLoc-1, lettersUsed);
findWords(word, iLoc+1, jLoc+1, lettersUsed);
lettersUsed[iLoc][jLoc] = false;
}
它只是运行,很少会说找到了一个词。它也需要很长时间才能运行,大约一个小时。我看不出我的错误在哪里,我也看不出我可以在哪里犯错。任何帮助都会很棒!
最佳答案
这将在所有 10-、11-、12-、13-、14- 等字母单词中进行组合爆炸式搜索。一旦当前 word
不是字典中任何单词的前缀,您应该添加代码来修剪搜索。
此外,您正在使用 ArrayList 作为单词列表。使用 wordsPossible.contains(word)
搜索平面列表非常慢,因为它每次都会扫描整个列表。对于一个包含 80,000 个单词的词典,这平均需要 40,000 次迭代。
更合适的数据结构是 tree set或 prefix tree (或尝试)。两者都针对快速查找进行了优化,非常适合上述前缀检查。对于树集,ceiling()方法会很方便。参见 this question有关 Java 中的尝试的信息。
关于java - 为什么 Boggle Solver 不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13692573/
打开几个编写宏/代码的示例,我突然被一个似乎安全的代码卡住了。求解器 (SOLVER.XLAM) 这是值得注意的,我想从我的系统中删除它。我想这不是一个相关的代码。谁能告诉我我应该怎么做?我已经安装了
是否可以使用 MSF api 将变量指定为半整数(V = 0 或 a = 5; Q1 = 5; Q2 10 * VPositive<= V <= 20 * VPositive ] ] 如果您使用
我正在研究线性和非线性编程(优化)框架的选项。 要求是: 支持大约线性和非线性规划问题。 100-1000 个变量和最多约 1000 个约束(我认为这很简单)。非线性问题具有涉及多个变量的乘法或除法的
SMT-Solver 可用于约束求解。众所周知,CSP 求解器也用于约束求解多年。那么 SMT 求解器与 CSP 求解器相比有什么优势呢? 最佳答案 这完全取决于你想做什么。您可以将两者都转换为 SA
我正在查看 Caffe LeNet 教程 here我想到了一个问题: 这两个代码有什么区别: self.solver.step(1) 和 self.solver.net.forward() # tr
我正在使用 CBC 求解器在 PyCharm 上解决优化问题,但一直遇到此错误: 错误:求解器 (cbc) 返回非零返回代码 (3221225781) 和 pyutilib.common._excep
我是 microsoft excels 求解器的用户,我很确定不可能求解最大化两个值。我想知道是否有人可能有另一种聪明的方法来做到这一点。 基本上,我有一列介于 1 到 30 之间的数字,我需要查看它
我想从数值的角度理解混合建模(特别是状态事件)背后的一般思想(尽管我不是数学家 :))。鉴于以下 Modelica 模型: model BouncingBall constant Real g
最近,我开始研究形式验证技术。在文献中,模型检查器和求解器可以以某种方式互换使用。 但是,模型检查器和求解器如何相互连接? p.s.如果建议提供一些论文或链接,我将不胜感激。 最佳答案 为了执行模型检
我希望这对某人来说是显而易见的。我只使用过 GLPK/MathProg。 我无法弄清楚 GNU MathProg(在 GLPK 内)中的语法来执行以下操作,例如: set PartsOfWeek; s
我有一个(对我来说)非常复杂的问题。我有两个向量: vectora <- c(111, 245, 379, 516, 671) vectorb <- c(38, 54, 62, 67, 108) 此外
我在 VBA 循环中使用 Excel 2007 中的内置求解器来解决许多不同的问题。有时,求解器会达到最大时间,这会导致出现弹出对话框,询问用户是否要继续、停止或结束。在所有情况下,我都希望它结束
我在 PC 上的 Excel 2010 中创建了一个程序,该程序依赖于 Excel 的内置求解器。我确保它适用于 PC 版 Excel 2010 和 Excel 2013。然后我尝试在 Excel 2
在汽车行业,当您购买汽车时,您有数千种不同的组件可供选择。并非每个组件都是可组合的,因此对于每辆汽车,都存在许多用命题逻辑表达的规则。就我而言,每辆车都有 2000 到 4000 条规则。 它们看起来
有没有办法让我们知道解算器中添加了多少约束?例如,我们初始化一个 z3 求解器 s = Solver(),然后使用 s.add() 添加约束。我们如何获得最终添加到求解器中的约束数量? 最佳答案 您可
我正在尝试修改 ceres 的默认行为,即计算残差的平方和作为成本函数。我希望它只计算总和(残差已经以只能为正的方式计算) 根据文档,我应该使用 ConditionedCostFunction 这是我
我有这个方法来求解根据增量返回 2 种类型数组的二次方程(如果小于零则有复数解) public static final String[] quadEquationSolver(double a, d
p = Int('p') q = Int('q') s = Solver() s.add(1<=p<=9, 1<=q<=19, 5<(3*p-4*q)<10) s.check() print s.mo
“问题”在标题中不应该是问题的情况。 我想为一组问题(类 Problem 的所有子项)实现一个求解器(类 Solver),这些问题或多或少共享同一组方法。我目前的设计是这样的: 在solver.h :
我为所有方向创建了一个单词求解器。它可以水平、垂直和反向查找单词。然而,我在让它走向各个方向时遇到了问题。所以把“你好”放在: H E i l x L p q c L O m 任何人
我是一名优秀的程序员,十分优秀!