<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FCollections_Data_Structure%2FInfix_Postfix</id>
		<title>Java/Collections Data Structure/Infix Postfix - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FCollections_Data_Structure%2FInfix_Postfix"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Collections_Data_Structure/Infix_Postfix&amp;action=history"/>
		<updated>2026-04-06T08:29:04Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Collections_Data_Structure/Infix_Postfix&amp;diff=9145&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Collections_Data_Structure/Infix_Postfix&amp;diff=9145&amp;oldid=prev"/>
				<updated>2010-06-01T07:26:39Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 07:26, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Collections_Data_Structure/Infix_Postfix&amp;diff=9144&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Collections_Data_Structure/Infix_Postfix&amp;diff=9144&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:50Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Converts infix arithmetic expressions to postfix ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.io.IOException;&lt;br /&gt;
public class InToPost {&lt;br /&gt;
  private Stack theStack;&lt;br /&gt;
  private String input;&lt;br /&gt;
  private String output = &amp;quot;&amp;quot;;&lt;br /&gt;
  public InToPost(String in) {&lt;br /&gt;
    input = in;&lt;br /&gt;
    int stackSize = input.length();&lt;br /&gt;
    theStack = new Stack(stackSize);&lt;br /&gt;
  }&lt;br /&gt;
  public String doTrans() {&lt;br /&gt;
    for (int j = 0; j &amp;lt; input.length(); j++) {&lt;br /&gt;
      char ch = input.charAt(j);&lt;br /&gt;
      switch (ch) {&lt;br /&gt;
      case &amp;quot;+&amp;quot;: &lt;br /&gt;
      case &amp;quot;-&amp;quot;:&lt;br /&gt;
        gotOper(ch, 1); &lt;br /&gt;
        break; //   (precedence 1)&lt;br /&gt;
      case &amp;quot;*&amp;quot;: // it&amp;quot;s * or /&lt;br /&gt;
      case &amp;quot;/&amp;quot;:&lt;br /&gt;
        gotOper(ch, 2); // go pop operators&lt;br /&gt;
        break; //   (precedence 2)&lt;br /&gt;
      case &amp;quot;(&amp;quot;: // it&amp;quot;s a left paren&lt;br /&gt;
        theStack.push(ch); // push it&lt;br /&gt;
        break;&lt;br /&gt;
      case &amp;quot;)&amp;quot;: // it&amp;quot;s a right paren&lt;br /&gt;
        gotParen(ch); // go pop operators&lt;br /&gt;
        break;&lt;br /&gt;
      default: // must be an operand&lt;br /&gt;
        output = output + ch; // write it to output&lt;br /&gt;
        break;&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    while (!theStack.isEmpty()) {&lt;br /&gt;
      output = output + theStack.pop();&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println(output);&lt;br /&gt;
    return output; // return postfix&lt;br /&gt;
  }&lt;br /&gt;
  public void gotOper(char opThis, int prec1) {&lt;br /&gt;
    while (!theStack.isEmpty()) {&lt;br /&gt;
      char opTop = theStack.pop();&lt;br /&gt;
      if (opTop == &amp;quot;(&amp;quot;) {&lt;br /&gt;
        theStack.push(opTop);&lt;br /&gt;
        break;&lt;br /&gt;
      }// it&amp;quot;s an operator&lt;br /&gt;
      else {// precedence of new op&lt;br /&gt;
        int prec2;&lt;br /&gt;
        if (opTop == &amp;quot;+&amp;quot; || opTop == &amp;quot;-&amp;quot;)&lt;br /&gt;
          prec2 = 1;&lt;br /&gt;
        else&lt;br /&gt;
          prec2 = 2;&lt;br /&gt;
        if (prec2 &amp;lt; prec1) // if prec of new op less&lt;br /&gt;
        { //    than prec of old&lt;br /&gt;
          theStack.push(opTop); // save newly-popped op&lt;br /&gt;
          break;&lt;br /&gt;
        } else&lt;br /&gt;
          // prec of new not less&lt;br /&gt;
          output = output + opTop; // than prec of old&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    theStack.push(opThis);&lt;br /&gt;
  }&lt;br /&gt;
  public void gotParen(char ch){ &lt;br /&gt;
    while (!theStack.isEmpty()) {&lt;br /&gt;
      char chx = theStack.pop();&lt;br /&gt;
      if (chx == &amp;quot;(&amp;quot;) &lt;br /&gt;
        break; &lt;br /&gt;
      else&lt;br /&gt;
        output = output + chx; &lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  public static void main(String[] args) throws IOException {&lt;br /&gt;
    String input = &amp;quot;1+2*4/5-7+3/6&amp;quot;;&lt;br /&gt;
    String output;&lt;br /&gt;
    InToPost theTrans = new InToPost(input);&lt;br /&gt;
    output = theTrans.doTrans(); &lt;br /&gt;
    System.out.println(&amp;quot;Postfix is &amp;quot; + output + &amp;quot;\n&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  class Stack {&lt;br /&gt;
    private int maxSize;&lt;br /&gt;
  &lt;br /&gt;
    private char[] stackArray;&lt;br /&gt;
  &lt;br /&gt;
    private int top;&lt;br /&gt;
  &lt;br /&gt;
    public Stack(int max) {&lt;br /&gt;
      maxSize = max;&lt;br /&gt;
      stackArray = new char[maxSize];&lt;br /&gt;
      top = -1;&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public void push(char j) {&lt;br /&gt;
      stackArray[++top] = j;&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public char pop() {&lt;br /&gt;
      return stackArray[top--];&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public char peek() {&lt;br /&gt;
      return stackArray[top];&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public boolean isEmpty() {&lt;br /&gt;
      return (top == -1);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Parse postfix arithmetic expressions ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.io.IOException;&lt;br /&gt;
public class ParsePost {&lt;br /&gt;
  private Stack theStack;&lt;br /&gt;
  private String input;&lt;br /&gt;
  public ParsePost(String s) {&lt;br /&gt;
    input = s;&lt;br /&gt;
  }&lt;br /&gt;
  public int doParse() {&lt;br /&gt;
    theStack = new Stack(20);&lt;br /&gt;
    char ch;&lt;br /&gt;
    int j;&lt;br /&gt;
    int num1, num2, interAns;&lt;br /&gt;
    for (j = 0; j &amp;lt; input.length(); j++) {&lt;br /&gt;
      ch = input.charAt(j); &lt;br /&gt;
      theStack.displayStack(&amp;quot;&amp;quot; + ch + &amp;quot; &amp;quot;);&lt;br /&gt;
      if (ch &amp;gt;= &amp;quot;0&amp;quot; &amp;amp;&amp;amp; ch &amp;lt;= &amp;quot;9&amp;quot;) // if a number push it&lt;br /&gt;
        theStack.push((int) (ch - &amp;quot;0&amp;quot;));   &lt;br /&gt;
      else // it&amp;quot;s an operator&lt;br /&gt;
      {&lt;br /&gt;
        num2 = theStack.pop();&lt;br /&gt;
        num1 = theStack.pop();&lt;br /&gt;
        switch (ch) {&lt;br /&gt;
        case &amp;quot;+&amp;quot;:&lt;br /&gt;
          interAns = num1 + num2;&lt;br /&gt;
          break;&lt;br /&gt;
        case &amp;quot;-&amp;quot;:&lt;br /&gt;
          interAns = num1 - num2;&lt;br /&gt;
          break;&lt;br /&gt;
        case &amp;quot;*&amp;quot;:&lt;br /&gt;
          interAns = num1 * num2;&lt;br /&gt;
          break;&lt;br /&gt;
        case &amp;quot;/&amp;quot;:&lt;br /&gt;
          interAns = num1 / num2;&lt;br /&gt;
          break;&lt;br /&gt;
        default:&lt;br /&gt;
          interAns = 0;&lt;br /&gt;
        }&lt;br /&gt;
        theStack.push(interAns);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    interAns = theStack.pop();&lt;br /&gt;
    return interAns;&lt;br /&gt;
  }&lt;br /&gt;
  public static void main(String[] args) throws IOException {&lt;br /&gt;
    String input = &amp;quot;1-2+3*4+5/6-7+8*9&amp;quot;;&lt;br /&gt;
    int output;&lt;br /&gt;
    ParsePost aParser = new ParsePost(input);&lt;br /&gt;
    output = aParser.doParse();&lt;br /&gt;
    System.out.println(&amp;quot;Evaluates to &amp;quot; + output);&lt;br /&gt;
  }&lt;br /&gt;
  class Stack {&lt;br /&gt;
    private int maxSize;&lt;br /&gt;
  &lt;br /&gt;
    private int[] stackArray;&lt;br /&gt;
  &lt;br /&gt;
    private int top;&lt;br /&gt;
  &lt;br /&gt;
    public Stack(int size) {&lt;br /&gt;
      maxSize = size;&lt;br /&gt;
      stackArray = new int[maxSize];&lt;br /&gt;
      top = -1;&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public void push(int j) {&lt;br /&gt;
      stackArray[++top] = j;&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public int pop() {&lt;br /&gt;
      return stackArray[top--];&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public int peek() {&lt;br /&gt;
      return stackArray[top];&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public boolean isEmpty() {&lt;br /&gt;
      return (top == -1);&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public boolean isFull() {&lt;br /&gt;
      return (top == maxSize - 1);&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public int size() {&lt;br /&gt;
      return top + 1;&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public int peekN(int n) {&lt;br /&gt;
      return stackArray[n];&lt;br /&gt;
    }&lt;br /&gt;
  &lt;br /&gt;
    public void displayStack(String s) {&lt;br /&gt;
      System.out.print(s);&lt;br /&gt;
      System.out.print(&amp;quot;Stack (bottom&amp;gt;top): &amp;quot;);&lt;br /&gt;
      for (int j = 0; j &amp;lt; size(); j++) {&lt;br /&gt;
        System.out.print(peekN(j));&lt;br /&gt;
        System.out.print(&amp;quot; &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println(&amp;quot;&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>