- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
该作业旨在帮助理解和练习树概念和遍历。我应该使用树来评估前缀(抛光)表示法中的表达式,以及打印后缀(反向抛光)表示法和中缀表示法中的表达式。
这是给出的评估类(class)。
import java.util.*;
public class Evaluation
{
public static void main(String[] args)
{
System.out.print("Enter a prefix expression: ");
Scanner scanner = new Scanner(System.in);
// build an expression tree
Node root = buildTree(scanner);
// print prefix expression
System.out.println("prefix expression:");
preorder(root);
System.out.println();
// print postfix expression
System.out.println("postfix expression:");
postorder(root);
System.out.println();
// print infix expression
System.out.println("infix expression:");
inorder(root);
System.out.println();
// evaluate the expression using postfix
System.out.println("Result = " + evaluate(root));
}
// build an expression tree and return the root node of the tree
public static Node buildTree(Scanner sc)
{
// your code here
}
// Postfix expression is the result of a post-order traversal
public static void postorder(Node node)
{
// your code here
}
// Prefix expression is the result of a pre-order traversal
public static void preorder(Node node)
{
// your code here
}
// Infix expression is the result of a in-order traversal
public static void inorder(Node node)
{
// your code here
}
// Evaluate the expression tree using postorder traversal
public static int evaluate(Node node)
{
// your code here
}
}
编辑:这是我必须编写的 Node 类。
public class Node {
String value;
Node left, right;
Node(String value){
this.value = value;
}
Node(String value, Node left, Node right){
this.left = left;
this.right = right;
}
public boolean isLeaf(){
if()
return true;
}
}
作业的说明是使用给定的方法 buildTree 来构造一棵树,并以前缀表示法计算 4 个给定的表达式:
1.- + 10 * 2 8 3
2./* + 3 14 2 7
3.+ + 4 2 * 3 - 15 1
4./- % + 1 2 3 6 + 2 3
编辑:在之前的作业中,我必须使用堆栈来评估 Postfix 表达式,但是如何使用这棵树来构建和遍历来评估前缀表达式?(我假设操作数和运算符将是节点的值,然后节点将以某种方式链接。)
最佳答案
好吧,让我们考虑一下。是什么使节点成为叶子?
我想说叶子是没有子节点的节点。那么,如何使用以下 boolean 表达式进行 if
检查:if(left == null && right == null)
?
稍后编辑:事实上,您甚至不需要 if
检查。你可以简单地说,就像
public boolean isLeaf(){
return left == null && right == null;
}
另外,请注意您的重载构造函数
Node(String value, Node left, Node right){
this.left = left;
this.right = right;
}
未正确分配值
。
关于java - 我现在如何使用扫描仪 "build"树? (代码后有说明),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20385704/
Xcode 4 中的以下操作有什么作用? 为测试而构建 为运行而构建 为分析而构建 为存档而构建 我不确定何时使用这些(或是否使用其中任何一个)。 最佳答案 Running 用于运行您的应用(在 Ma
工具: Jenkins 版1.470 Maven 2 颠覆 环境 假设我的构建有许多项目 A-D。如图所示,依赖关系图存在。也就是说:B 依赖于 A 中的类,C 依赖于 B 中的类,D 依赖于 A 中
我正在创建一个软件项目,我想使用 autotools 为我生成 makefile 等脚本,我手动创建了 Makefile.am 和 configure.in 文件,我正在使用 autogen.sh 脚
什么yarn build命令做什么? 是 yarn build和 npm build相同?如果不是有什么区别? 最佳答案 yarn build和 npm build默认情况下不是现有的命令。我想你是说
如果我有一个包含许多相互依赖的项目的大型代码库,例如,projects/A、projects/B 和 projects/C ,其中 A 需要 B,B 需要 C,每个项目都有一个Cake 构建脚本,例如
我正在尝试使用 Wix/Detox 来测试我的 react-native 应用程序(iOS 版本)。我已成功遵循 https://github.com/wix/detox/blob/master/do
我们有许多编译 .NET 代码的 Nant 脚本。这些构建需要 5 到 10 分钟才能运行,我想找到一种方法来加速它们。 我们的 Nant 脚本看起来像
你好 当我在 windows 下使用 gnu 构建 ffmpeg-3.4.1 时,谁能帮我解决这个错误: /tmp/9747a756ee05ef34cc3fcf51eabde826/sysroot/u
构建解决方案/项目/程序意味着什么?我想确保我的定义是正确的(所以我在交谈时听起来不像个白痴)。在 IDE 中,您可以(如果我错了,请纠正我)编译源代码/编程代码为计算机可读的机器代码。您可以调试程序
为什么 Eclipse 在构建 Android 项目时会陷入无限循环,用于构建工作区...和(重新)构建工作区...和(重新)构建工作区... 这是一个已知的错误吗? 摆脱这个循环的正确方法是什么?
我的 Angular 项目是 @Angular4.3.3 ng build -prod 构建需要 77 秒 ng build --prod --build-optimizer=true 构建需要 19
所以我刚刚使用命令创建了一个 React Native 项目 react-native init "项目名称" 我进入应用程序级别的 build.gradle 以连接 firebase,但出现错误提示
我想弄清楚 TFS Online 2017 中的两个预定义变量之间是否存在差异:$(Build.Repository.LocalPath)和 $(Build.SourcesDirectory) .我有
编译项目时,当系统用户名匹配时,此脚本应将 Xcode 项目的构建版本递增 1。请记住,这些只是 Target->Build Phases->Run Script in Xcode 中脚本(不是 Ap
是否有一种工具可以在给定 MS Build 项目文件的情况下构建一个视觉对象,显示将在何时以及从哪个导入文件执行哪个目标? 如果给定一个解决方案文件,它会构建项目构建顺序的视觉效果? 最佳答案 是的,
我正在尝试使用 Bazel 进行以下设置。通过调用“bazel build”,Python 脚本应该生成未知数量的具有随机名称的 *.cc 文件,然后将这些文件编译成单个静态库(.a 文件),所有这些
我正在将我的 Cmake 项目迁移到 Bazel。我项目的根目录是 build我用来运行 Cmake 的文件夹。 迁移到 Bazel ,我需要创建一个 BUILD我的项目根目录下的文件。但是,在 ma
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 5 年前。 此帖子已于
当我的Dockerfile如下所示时,它运行良好。 ... RUN pip install git+https://user_name:my_password@github.com/repo_name
当前的自动构建功能集是否可以从存储库中添加新标签并标记生成的图像?还是我需要3party服务将新标签自动推送到Docker Registry? 最佳答案 目前不行。 当前(2014年10月)尚无Doc
我是一名优秀的程序员,十分优秀!