summaryrefslogtreecommitdiffstats
path: root/src/de/fhswf/in/inf/java1/aufgabe11/UPN.java
diff options
context:
space:
mode:
authorStefan Suhren <suhren.stefan@fh-swf.de>2014-12-15 00:55:59 +0100
committerStefan Suhren <suhren.stefan@fh-swf.de>2014-12-15 00:55:59 +0100
commit1a5f21d376fc05745410124a9ea717fb9dd0b10f (patch)
treedc891e1ee5e50fc0ff96b9b7a0659ad0dba0ca86 /src/de/fhswf/in/inf/java1/aufgabe11/UPN.java
parent0669d3e06127a04c2a419a10664a259847e194fb (diff)
downloadJava1-1a5f21d376fc05745410124a9ea717fb9dd0b10f.tar.gz
Java1-1a5f21d376fc05745410124a9ea717fb9dd0b10f.zip
Assignment No.11 implements classes.
Diffstat (limited to 'src/de/fhswf/in/inf/java1/aufgabe11/UPN.java')
-rw-r--r--src/de/fhswf/in/inf/java1/aufgabe11/UPN.java110
1 files changed, 110 insertions, 0 deletions
diff --git a/src/de/fhswf/in/inf/java1/aufgabe11/UPN.java b/src/de/fhswf/in/inf/java1/aufgabe11/UPN.java
new file mode 100644
index 0000000..25b939e
--- /dev/null
+++ b/src/de/fhswf/in/inf/java1/aufgabe11/UPN.java
@@ -0,0 +1,110 @@
+/**
+ *
+ */
+package de.fhswf.in.inf.java1.aufgabe11;
+
+import java.util.Stack;
+
+/**
+ * A class that calculates in UPN.
+ *
+ * @author $Author: $
+ * @version $Revision: $, $Date: $ UTC
+ */
+public class UPN
+{
+
+ private Stack<Double> upnStack = new Stack<>();
+
+ /**
+ * Empty constructor.
+ *
+ */
+ public UPN()
+ {
+ }
+
+ /**
+ * Reads a string and puts it on the UPN upnStack.
+ *
+ * @param upnString
+ * A space delimited string in UPN notation.
+ */
+ public final void calculate(String upnString)
+ {
+ if (upnString == null)
+ {
+ throw new IllegalArgumentException("UpnString can't be null.");
+ }
+ if (upnString.isEmpty())
+ {
+ throw new IllegalArgumentException("UpnString can't be empty.");
+ }
+
+ for (String string : upnString.split("\\s+"))
+ {
+ try
+ {
+ upnStack.add(Double.valueOf(string));
+ }
+ catch (NumberFormatException e)
+ {
+ double operand1 = 0;
+ double operand2 = 0;
+ if (upnStack.size() < 2)
+ {
+ throw new IllegalStateException(
+ "Two operands are needed for an operation.");
+ }
+
+ operand2 = upnStack.pop();
+ operand1 = upnStack.pop();
+
+ switch (string)
+ {
+ case "+":
+ upnStack.add(operand1 + operand2);
+ break;
+ case "-":
+ upnStack.add(operand1 - operand2);
+ break;
+ case "*":
+ upnStack.add(operand1 * operand2);
+ break;
+ case "/":
+ if (operand2 == 0)
+ {
+ throw new IllegalArgumentException("Divisor can't be 0.");
+ }
+ upnStack.add(operand1 / operand2);
+ break;
+ case "%":
+ if (operand2 == 0)
+ {
+ throw new IllegalArgumentException("Divisor can't be 0.");
+ }
+ upnStack.add(operand1 % operand2);
+ break;
+ default:
+ throw new IllegalArgumentException("String: \"" + string
+ + "\" is not a valid operator.");
+ }
+ }
+ }
+ }
+
+ /**
+ * Get the result of a calculation done before.
+ *
+ * @return The top most value on the UPN stack.
+ */
+ public final double getResult()
+ {
+ if (upnStack.empty())
+ {
+ throw new IllegalStateException("UPN stack is empty.");
+ }
+ return upnStack.peek();
+ }
+
+}