Problem:
microsoft-interview-questions 57 Answers
Given a value and a binary search tree.
Print all the paths(if there exists more than one) which sum up to that value. It can be any path in the tree. It doesn't have to be from the root.
My code:
I also pasted my code at
http://www.careercup.com/question?id=2971
import java.util.Stack;
public class BinarySearchTree {
private class Node {
int data;
Node left;
Node right;
Node(int v, Node left, Node right){
data = v;
this.left = left;
this.right = right;
}
}
public Node root;
public void insertNode(int data) {
if (root == null) {
root = new Node(data, null, null);
return;
}
Node cur = root;
do {
if(data >= cur.data) {
if(cur.right != null) cur = cur.right;
else {
cur.right = new Node(data, null, null);
return;
}
}else {
if(cur.left != null) cur = cur.left;
else {
cur.left = new Node(data, null, null);
return;
}
}
}while(cur != null);
}
public void inorder() {
System.out.println("\nin-order :");
printSubTreeInOrder(root);
}
public void preorder() {
System.out.println("\npre-order :");
printSubTreePreOrder(root);
}
private void printSubTreeInOrder(Node p){
if(p.left != null) printSubTreeInOrder(p.left);
System.out.print("\t" + p.data);
if(p.right != null) printSubTreeInOrder(p.right);
}
private void printSubTreePreOrder(Node p){
System.out.print("\t" + p.data);
if(p.left != null) printSubTreePreOrder(p.left);
if(p.right != null) printSubTreePreOrder(p.right);
}
public void printAllPathWithSum(int sum){
Stack<Node> path = new Stack<Node>();
findPath(root, sum, path);
}
private void printPath(Stack<Node> path){
System.out.print("\nFind Path:");
for(Node n: path){
System.out.print("\t" + n.data);
}
}
private void findPath(Node p, int value, Stack<Node> path){
if(p == null) return;
if(p.data == value){
path.push(p);
printPath(path);
path.pop();
}else {
path.push(p);
if(p.left != null) findPath(p.left, value - p.data, path);
if(p.right != null)findPath(p.right, value- p.data, path);
path.pop();
}
if(p.left != null) findPath(p.left, value , path);
if(p.right != null)findPath(p.right, value, path);
}
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
BinarySearchTree tree = new BinarySearchTree();
tree.insertNode(5);
tree.insertNode(2);
tree.insertNode(7);
tree.insertNode(1);
tree.insertNode(3);
tree.insertNode(9);
tree.inorder();
tree.preorder();
tree.printAllPathWithSum(1);
tree.printAllPathWithSum(0);
tree.printAllPathWithSum(16);
tree.printAllPathWithSum(9);
}
}
分享到:
相关推荐
A recent study published in *The Journal of Systems and Software* (Volume 85, 2012, Pages 1558–1576) introduces a new profiling technique called "Profiling All Paths" (PAP). This approach aims to ...
A multistage graph is a graph (1) G=(V,E) with V partitioned into K >= 2 disjoint subsets such that if (a,b) is in E, then a is in Vi , and b is in Vi+1 for some subsets in the partition; and (2) | ...
As a consequence, there are a number of aspects that we chose not to touch, or to do so only barely. One omission is the study of rough paths of arbitrarily low regularity: we do provide hints at the ...
Finding Top-k Shortest Paths with Diversity 在计算机科学和信息技术领域中,寻找 Top-k 最短简单路径问题是一个经典的问题。该问题的应用非常广泛,例如在路线规划、交通导航、物流等领域都有重要的实践价值。本...
Find the number of paths that sum to a given value. The path does not need to start or end at the root or a leaf, but it must go downwards (traveling only from parent nodes to child nodes
Adds a response header with the given name and value. addIntHeader(String, int) - Method in class javax.servlet.http.HttpServletResponseWrapper The default behavior of this method is to call ...
Fixed : Issue with scrolling and selecting value in iOS in TTMSFMXSpinner Fixed : Issue with escape key not cancelling edit mode in TTMSFMXGrid v1.6.0.1 Fixed : Issue with double databinding ...
27. Creation of a botnet requires an attacker to find vulnerability in some application or system (e.g. exploiting the buffer overflow vulnerability that might exist in an application). After finding ...
A new concept high-voltage pseudo-pchannel lateral double-diffused MOS (p-LDMOS) with multiple current paths for conduction is proposed and investigated in this paper. The proposed power device ...
java基础 java_leetcode题解之 All Paths From Source to Target.java
In a high level query and data manipulation language such as SQL, requests are stated non-procedurally, without reference to access paths. This paper describes how System R chooses access paths for ...
All of a project's header files should be listed as descentants of the project's source directory without use of UNIX directory shortcuts . (the current directory) or .. (the parent directory). For...
NOTE: only valid with A as the first input C is a NxN cost (perhaps distance) matrix, where C(I,J) contains the value of the cost to move from point I to point J NOTE: only valid with A as the ...
This course begins with a 3D beginner-level primer to 3D concepts and some basic examples to get you started with the most important features that Three.js has to offer. You’ll learn how to quickly ...
with a scrollable list and can display and edit a field in a dataset or can works as non data-aware combo edit control. TDBNumberEditEh component represents a single-line number edit control that ...
完成这一步后,将`universal`目录下的`libssl.a`和`libcrypto.a`添加到Xcode项目的`Link Binary With Libraries`阶段,并确保它们被包含在项目的`Copy Files`构建阶段,以便在应用包中包含这些静态库。 接下来,...
This course begins with a 3D beginner-level primer to 3D concepts and some basic examples to get you started with the most important features that Three.js has to offer. You’ll learn how to quickly ...
with a scrollable list and can display and edit a field in a dataset or can works as non data-aware combo edit control. TDBNumberEditEh component represents a single-line number edit control that ...