TP 07
This commit is contained in:
40
DEV 3.2/TP07/Prefixe/Node.java
Normal file
40
DEV 3.2/TP07/Prefixe/Node.java
Normal file
@@ -0,0 +1,40 @@
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class Node<T> {
|
||||
private T value;
|
||||
private List<Node<T>> subNodes;
|
||||
|
||||
public Node(T value) {
|
||||
this.value = value;
|
||||
this.subNodes = new ArrayList<>();
|
||||
}
|
||||
|
||||
public T getValue() {
|
||||
return value;
|
||||
}
|
||||
|
||||
public void setValue(T value) {
|
||||
this.value = value;
|
||||
}
|
||||
|
||||
public List<Node<T>> getSubNodes() {
|
||||
return this.subNodes;
|
||||
}
|
||||
|
||||
public boolean addSubNode(Node<T> node) {
|
||||
return subNodes.add(node);
|
||||
}
|
||||
|
||||
public boolean remSubNode(Node<T> node) {
|
||||
return subNodes.remove(node);
|
||||
}
|
||||
|
||||
public void showNode() {
|
||||
System.out.print(value.toString() + " ");
|
||||
|
||||
for (Node<T> subNode : subNodes) {
|
||||
subNode.showNode();
|
||||
}
|
||||
}
|
||||
}
|
34
DEV 3.2/TP07/Prefixe/Prefixe.java
Normal file
34
DEV 3.2/TP07/Prefixe/Prefixe.java
Normal file
@@ -0,0 +1,34 @@
|
||||
import java.util.ArrayDeque;
|
||||
|
||||
/**
|
||||
* Arithmetique
|
||||
*/
|
||||
public class Prefixe {
|
||||
public static void main(String[] args) {
|
||||
ArrayDeque<Node<String>> pile = new ArrayDeque<>();
|
||||
|
||||
for (String arg : args) {
|
||||
try {
|
||||
Integer.parseInt(arg);
|
||||
pile.addFirst(new Node<String>(arg));
|
||||
} catch (NumberFormatException e) {
|
||||
if (pile.size() < 2) {
|
||||
System.err.println("Invalid stack size.");
|
||||
return;
|
||||
}
|
||||
|
||||
Node<String> n2 = pile.pollFirst();
|
||||
Node<String> n1 = pile.pollFirst();
|
||||
|
||||
Node<String> n3 = new Node<String>(arg);
|
||||
n3.addSubNode(n1);
|
||||
n3.addSubNode(n2);
|
||||
|
||||
pile.addFirst(n3);
|
||||
}
|
||||
}
|
||||
|
||||
pile.pollFirst().showNode();
|
||||
System.out.println("");
|
||||
}
|
||||
}
|
19
DEV 3.2/TP07/Prefixe/Tree.java
Normal file
19
DEV 3.2/TP07/Prefixe/Tree.java
Normal file
@@ -0,0 +1,19 @@
|
||||
public class Tree<T> {
|
||||
private Node<T> rootNode;
|
||||
|
||||
public Tree() {
|
||||
rootNode = new Node<T>(null);
|
||||
}
|
||||
|
||||
public void setRootNode(Node<T> rootNode) {
|
||||
this.rootNode = rootNode;
|
||||
}
|
||||
|
||||
public Node<T> getRootNode() {
|
||||
return rootNode;
|
||||
}
|
||||
|
||||
public void showTree() {
|
||||
rootNode.showNode();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user