zoukankan      html  css  js  c++  java
  • 第七周

      团队作业题目是做一个安卓计算器,而我的任务就是进行字符串的分析,我本该,说的简单点就是正确计算出一个表达式。

     上学期和许清老师学了编译原理,想到LL(1)文法,使用递归下降可以正确分析一段文法,看了两天后,突然想明白,我只要计算出结果,并不需要具体的分析过

    程比如消除做递归,消除回溯啊。再加上我的安卓基数只是入门,还是不写那么复杂的吧,于是挑了一个数据结构里简单的栈的操作进行计算,具体思路如下:

      1.输入一个表达式,存在字符数组里(Java里可以建数组,想用二叉树,但Java里没有指针)

      2.把这个表达式由中缀式转换为后缀式。中缀式改为后缀式优点:中缀式和后缀式的操作数出现的顺序是一样的,只是操作符顺序不一样,而且后缀是表达式无括号,在出入栈的时候我把(,),左右括号的优先级同其他符号进行比较后,直接出栈不保存。

      3.逐个读取后缀式(保存在一个数组里)的字符,如果是0~9,就一直读到下一位不是数字为止,把这几个数字转为整形数据入栈(数据栈),遇见操作符则连续出栈两个数,并用操作符进行运算。

    计算 结果自然也是一个数据,所以计算结果也要入栈。读后缀式一直读到’‘为止。

      4.最后,计算结果出栈,如果此时栈不空,则有错。

    具体代码在  https://git.coding.net/Wondove/wonderful5.git中,最新的biao_da_shi文件中。

      

  • 相关阅读:
    poj 3616 Milking Time
    poj 3176 Cow Bowling
    poj 2229 Sumsets
    poj 2385 Apple Catching
    poj 3280 Cheapest Palindrome
    hdu 1530 Maximum Clique
    hdu 1102 Constructing Roads
    codeforces 592B The Monster and the Squirrel
    CDOJ 1221 Ancient Go
    hdu 1151 Air Raid(二分图最小路径覆盖)
  • 原文地址:https://www.cnblogs.com/wodove/p/5405617.html
Copyright © 2011-2022 走看看