JAVA数据结构--解析数学表达式

简介: JAVA用栈解析数学表达式(如4*(7+4)): 1 // brackets.java 2 // stacks used to check matching brackets 3 // to run this program: C>java bracketsApp 4 import java.

JAVA用栈解析数学表达式(如4*(7+4)):

  1 // brackets.java
  2 // stacks used to check matching brackets
  3 // to run this program: C>java bracketsApp
  4 import java.io.*;                 // for I/O
  5 ////////////////////////////////////////////////////////////////
  6 class StackX
  7    {
  8    private int maxSize;
  9    private char[] stackArray;
 10    private int top;
 11 //--------------------------------------------------------------
 12    public StackX(int s)       // constructor
 13       {
 14       maxSize = s;
 15       stackArray = new char[maxSize];
 16       top = -1;
 17       }
 18 //--------------------------------------------------------------
 19    public void push(char j)  // put item on top of stack
 20       {
 21       stackArray[++top] = j;
 22       }
 23 //--------------------------------------------------------------
 24    public char pop()         // take item from top of stack
 25       {
 26       return stackArray[top--];
 27       }
 28 //--------------------------------------------------------------
 29    public char peek()        // peek at top of stack
 30       {
 31       return stackArray[top];
 32       }
 33 //--------------------------------------------------------------
 34    public boolean isEmpty()    // true if stack is empty
 35       {
 36       return (top == -1);
 37       }
 38 //--------------------------------------------------------------
 39    }  // end class StackX
 40 ////////////////////////////////////////////////////////////////
 41 class BracketChecker
 42    {
 43    private String input;                   // input string
 44 //--------------------------------------------------------------
 45    public BracketChecker(String in)        // constructor
 46       { input = in; }
 47 //--------------------------------------------------------------
 48    public void check()
 49       {
 50       int stackSize = input.length();      // get max stack size
 51       StackX theStack = new StackX(stackSize);  // make stack
 52 
 53       for(int j=0; j<input.length(); j++)  // get chars in turn
 54          {
 55          char ch = input.charAt(j);        // get char
 56          switch(ch)
 57             {
 58             case '{':                      // opening symbols
 59             case '[':
 60             case '(':
 61                theStack.push(ch);          // push them
 62                break;
 63 
 64             case '}':                      // closing symbols
 65             case ']':
 66             case ')':
 67                if( !theStack.isEmpty() )   // if stack not empty,
 68                   {
 69                   char chx = theStack.pop();  // pop and check
 70                   if( (ch=='}' && chx!='{') ||
 71                       (ch==']' && chx!='[') ||
 72                       (ch==')' && chx!='(') )
 73                      System.out.println("Error: "+ch+" at "+j);
 74                   }
 75                else                        // prematurely empty
 76                   System.out.println("Error: "+ch+" at "+j);
 77                break;
 78             default:    // no action on other characters
 79                break;
 80             }  // end switch
 81          }  // end for
 82       // at this point, all characters have been processed
 83       if( !theStack.isEmpty() )
 84          System.out.println("Error: missing right delimiter");
 85       }  // end check()
 86 //--------------------------------------------------------------
 87    }  // end class BracketChecker
 88 ////////////////////////////////////////////////////////////////
 89 class BracketsApp
 90    {
 91    public static void main(String[] args) throws IOException
 92       {
 93       String input;
 94       while(true)
 95          {
 96          System.out.print(
 97                       "Enter string containing delimiters: ");
 98          System.out.flush();
 99          input = getString();     // read a string from kbd
100          if( input.equals("") )   // quit if [Enter]
101             break;
102                                   // make a BracketChecker
103          BracketChecker theChecker = new BracketChecker(input);
104          theChecker.check();      // check brackets
105          }  // end while
106       }  // end main()
107 //--------------------------------------------------------------
108    public static String getString() throws IOException
109       {
110       InputStreamReader isr = new InputStreamReader(System.in);
111       BufferedReader br = new BufferedReader(isr);
112       String s = br.readLine();
113       return s;
114       }
115 //--------------------------------------------------------------
116    }  // end class BracketsApp
117 ////////////////////////////////////////////////////////////////

 

相关文章
|
8月前
|
Java
【Java实例-小兵拆炸弹】Java打造数学挑战-拆炸弹
今天,我将向大家分享一款用Java开发的控制台小案例——“小兵拆炸弹”。游戏规则:玩家需要在有限的尝试次数内解开一系列数学题,以成功拆解炸弹。游戏的目标是连续答对五道数学题,每道题都由系统随机生成。如果玩家在五次机会内成功解密,游戏胜利;否则,炸弹爆炸,游戏结束。
177 0
|
11月前
|
机器学习/深度学习 人工智能 Java
Java机器学习实战:基于DJL框架的手写数字识别全解析
在人工智能蓬勃发展的今天,Python凭借丰富的生态库(如TensorFlow、PyTorch)成为AI开发的首选语言。但Java作为企业级应用的基石,其在生产环境部署、性能优化和工程化方面的优势不容忽视。DJL(Deep Java Library)的出现完美填补了Java在深度学习领域的空白,它提供了一套统一的API,允许开发者无缝对接主流深度学习框架,将AI模型高效部署到Java生态中。本文将通过手写数字识别的完整流程,深入解析DJL框架的核心机制与应用实践。
699 3
|
11月前
|
存储 设计模式 Java
重学Java基础篇—ThreadLocal深度解析与最佳实践
ThreadLocal 是一种实现线程隔离的机制,为每个线程创建独立变量副本,适用于数据库连接管理、用户会话信息存储等场景。
401 5
|
11月前
|
存储 监控 安全
重学Java基础篇—类的生命周期深度解析
本文全面解析了Java类的生命周期,涵盖加载、验证、准备、解析、初始化、使用及卸载七个关键阶段。通过分阶段执行机制详解(如加载阶段的触发条件与技术实现),结合方法调用机制、内存回收保护等使用阶段特性,以及卸载条件和特殊场景处理,帮助开发者深入理解JVM运作原理。同时,文章探讨了性能优化建议、典型异常处理及新一代JVM特性(如元空间与模块化系统)。总结中强调安全优先、延迟加载与动态扩展的设计思想,并提供开发建议与进阶方向,助力解决性能调优、内存泄漏排查及框架设计等问题。
483 5
|
11月前
|
Java 开发者
重学Java基础篇—Java类加载顺序深度解析
本文全面解析Java类的生命周期与加载顺序,涵盖从加载到卸载的七个阶段,并深入探讨初始化阶段的执行规则。通过单类、继承体系的实例分析,明确静态与实例初始化的顺序。同时,列举六种触发初始化的场景及特殊场景处理(如接口初始化)。提供类加载完整流程图与记忆口诀,助于理解复杂初始化逻辑。此外,针对空指针异常等问题提出排查方案,并给出最佳实践建议,帮助开发者优化程序设计、定位BUG及理解框架机制。最后扩展讲解类加载器层次与双亲委派机制,为深入研究奠定基础。
443 0
|
11月前
|
安全 IDE Java
重学Java基础篇—Java Object类常用方法深度解析
Java中,Object类作为所有类的超类,提供了多个核心方法以支持对象的基本行为。其中,`toString()`用于对象的字符串表示,重写时应包含关键信息;`equals()`与`hashCode()`需成对重写,确保对象等价判断的一致性;`getClass()`用于运行时类型识别;`clone()`实现对象复制,需区分浅拷贝与深拷贝;`wait()/notify()`支持线程协作。此外,`finalize()`已过时,建议使用更安全的资源管理方式。合理运用这些方法,并遵循最佳实践,可提升代码质量与健壮性。
342 1
|
11月前
|
Java
课时15:Java运算符(基础数学运算符)
课时15介绍了Java中的基础数学运算符,涵盖加、减、乘、除及自增自减运算。强调了运算符的优先级和使用括号的重要性,并通过范例展示了四则运算与自增自减的具体应用。提醒编写代码时应保持简洁,避免复杂的表达式,确保代码易读性和可维护性。
166 7
|
11月前
|
传感器 监控 Java
Java代码结构解析:类、方法、主函数(1分钟解剖室)
### Java代码结构简介 掌握Java代码结构如同拥有程序世界的建筑蓝图,类、方法和主函数构成“黄金三角”。类是独立的容器,承载成员变量和方法;方法实现特定功能,参数控制输入环境;主函数是程序入口。常见错误包括类名与文件名不匹配、忘记static修饰符和花括号未闭合。通过实战案例学习电商系统、游戏角色控制和物联网设备监控,理解类的作用、方法类型和主函数任务,避免典型错误,逐步提升编程能力。 **脑图速记法**:类如太空站,方法即舱段;main是发射台,static不能换;文件名对仗,括号要成双;参数是坐标,void不返航。
443 5
|
12月前
|
Java API 数据处理
深潜数据海洋:Java文件读写全面解析与实战指南
通过本文的详细解析与实战示例,您可以系统地掌握Java中各种文件读写操作,从基本的读写到高效的NIO操作,再到文件复制、移动和删除。希望这些内容能够帮助您在实际项目中处理文件数据,提高开发效率和代码质量。
349 4
|
XML JSON Java
Java中Log级别和解析
日志级别定义了日志信息的重要程度,从低到高依次为:TRACE(详细调试)、DEBUG(开发调试)、INFO(一般信息)、WARN(潜在问题)、ERROR(错误信息)和FATAL(严重错误)。开发人员可根据需要设置不同的日志级别,以控制日志输出量,避免影响性能或干扰问题排查。日志框架如Log4j 2由Logger、Appender和Layout组成,通过配置文件指定日志级别、输出目标和格式。

推荐镜像

更多
  • DNS