Android_jiemian_activity_zw

package com.example.walker.calculator;


import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;


import java.util.ArrayList;
import java.util.EmptyStackException;
import java.util.List;
import java.util.Stack;
import java.util.regex.Matcher;
import java.util.regex.Pattern;




public class MainActivity extends AppCompatActivity {
    private int[] idNum = {R.id.txt0, R.id.txt1, R.id.txt2,
            R.id.txt3, R.id.txt4, R.id.txt5, R.id.txt6,
            R.id.txt7, R.id.txt8, R.id.txt9};  //数字Number输入
    private int[] idCal = {R.id.txtPlus, R.id.txtMinus,
            R.id.txtMul, R.id.txtDiv, R.id.txtLeft,
            R.id.txtRight, R.id.txtDot};  //运算符
    private Button[] buttonsCal = new Button[idCal.length];
    private Button[] buttonsNum = new Button[idNum.length];
    private Button buttonEqu;   //=
    private Button buttonClear;  // AC
    private Button buttonDel;
    private EditText input;
    private EditText output;
    private static String Text;


    @Override
    /**
     * input为输入字符行,
     * output为结果。
     */
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        input = (EditText) findViewById(R.id.input);
        input.setText("");
        //input.setEnabled(false);//禁止点击
        output = (EditText) findViewById(R.id.output);
        output.setText("0");
        output.setEnabled(false);//禁止点击
        buttonEqu = (Button) findViewById(R.id.txtIs);
        buttonEqu.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                output.setText(new Calculate(input.getText().toString()).str);
            }
        });
        //AC 按钮监听
        buttonClear = (Button) findViewById(R.id.txtClear);
        buttonClear.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                input.setText("");
                output.setText("0");
            }
        });
        //DEL按钮监听
        buttonDel = (Button) findViewById(R.id.txtDel);


        buttonDel.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {


                if (!input.getText().toString().isEmpty()) {
                    Text = input.getText().toString();
                    Text = Text.substring(0, Text.length() - 1);
                    input.setText(Text);
                }
            }
        });
/**
 * 注册单击事件
 */
        for (int index = 0; index < idCal.length; index++) {
            //运算符
            buttonsCal[index] = (Button) findViewById(idCal[index]);
            buttonsCal[index].setOnClickListener(new CalOnClick(buttonsCal[index].getText().toString()));


        }
        for (int i = 0; i < idNum.length; i++) {
            //数字
            buttonsNum[i] = (Button) findViewById(idNum[i]);
            buttonsNum[i].setOnClickListener(new NumberOnClick(buttonsNum[i].getText().toString()));
        }




    }


    //继承OnClick接口
    class NumberOnClick implements View.OnClickListener {
        String Msg;


        /**
         * @param msg 点击按钮传入字符
         */
        public NumberOnClick(String msg) {
            Msg = msg;
        }


        @Override
        public void onClick(View v) {
            if (!output.getText().toString().equals("")) {
                input.setText("");
                output.setText("");
            }
            input.append(Msg);
        }
    }


    class CalOnClick implements View.OnClickListener {
        String Msg;
        String[] calSymbol = {"+", "-", "*", "/", "."};


        public CalOnClick(String msg) {


            Msg = msg;
        }


        @Override
        public void onClick(View v) {
            if (!output.getText().toString().equals("")) {
                input.setText("");
                output.setText("");
            }
            // 检查是否运算符重复输入
            for (int i = 0; i < calSymbol.length; i++) {
                if (Msg.equals(calSymbol[i])) {
                    if (input.getText().toString().split("")
                            [input.getText().toString().split("").length - 1].equals(calSymbol[i])) {
                        Msg = "";
                    }


                }
            }
            input.append(Msg);
        }
    }


    /**
     * 运算类,返回一个String结果
     */
    public class Calculate {
        public String s1;
        StringBuilder str;


        public Calculate(String m) {
            this.s1 = m;
            try {
                eval();
            } catch (Exception e) {
                str.delete(0, str.length());
                str.append("输入格式错误!");
            }
        }


        /**
         * 中缀表达式转后缀表达式
         * <p>
         * 遍历中缀的list
         * 1、数字时,加入后缀list
         * 2、“(”时,压栈
         * 3、 若为 ')',则依次弹栈,把弹出的运算符加入后缀表达式中,直到出现'(';
         * 4、若为运算符,对做如下处置
         * 1、如果栈为空,则压栈
         * 2、如果栈不为空:
         * 1、stack.peek().equals("(")  则压栈
         * 2、比较str和stack.peek()的优先级
         * 1、如果>,则运算符压栈
         * 2、<=的情况:当栈不为空时:
         * 1、stack.peek()是左括号,压栈
         * 2、<=,把peek加入后缀表达式,弹栈
         * 3、>,把运算符压栈,停止对栈的操作
         * 执行完栈的操作之后,还得判断:如果栈为空,运算符压栈
         */
        public List<String> midToAfter(List<String> midList) throws EmptyStackException {
            List<String> afterList = new ArrayList<String>();
            Stack<String> stack = new Stack<String>();
            for (String str : midList) {
                int flag = this.matchWitch(str);
                switch (flag) {
                    case 7:
                        afterList.add(str);
                        break;
                    case 1:
                        stack.push(str);
                        break;
                    case 2:
                        String pop = stack.pop();
                        while (!pop.equals("(")) {
                            afterList.add(pop);
                            pop = stack.pop();
                        }
                        break;
                    default:
                        if (stack.isEmpty()) {
                            stack.push(str);
                            break;
                        } else {
                            if (stack.peek().equals("(")) {
                                stack.push(str);
                                break;
                            } else {
                                int ji1 = this.youxianji(str);
                                int ji2 = this.youxianji(stack.peek());
                                if (ji1 > ji2) {
                                    stack.push(str);
                                } else {
                                    while (!stack.isEmpty()) {
                                        String f = stack.peek();
                                        if (f.equals("(")) {
                                            stack.push(str);
                                            break;
                                        } else {
                                            if (this.youxianji(str) <= this.youxianji(f)) {
                                                afterList.add(f);
                                                stack.pop();
                                            } else {
                                                stack.push(str);
                                                break;
                                            }
                                        }
                                    }
                                    if (stack.isEmpty()) {
                                        stack.push(str);
                                    }
                                }
                                break;
                            }
                        }
                }
            }
            while (!stack.isEmpty()) {
                afterList.add(stack.pop());
            }
            StringBuffer sb = new StringBuffer();
            for (String s : afterList) {
                sb.append(s + " ");
            }
            //System.out.println(sb.toString());
            return afterList;
        }


        /**
         * 判断运算符的优先级
         */
        public int youxianji(String str) {
            int result = 0;
            if (str.equals("+") || str.equals("-")) {
                result = 1;
            } else {
                result = 2;
            }
            return result;
        }


        /**
         * 判断字符串属于操作数、操作符还是括号
         */
        public int matchWitch(String s) {
            if (s.equals("(")) {
                return 1;
            } else if (s.equals(")")) {
                return 2;
            } else if (s.equals("+")) {
                return 3;
            } else if (s.equals("-")) {
                return 4;
            } else if (s.equals("*")) {
                return 5;
            } else if (s.equals("/")) {
                return 6;
            } else {
                return 7;
            }
        }


        /**
         * 计算a@b的简单方法
         */
        public Double singleEval(Double pop2, Double pop1, String str) {
            Double value = 0.0;
            if (str.equals("+")) {
                value = pop2 + pop1;
            } else if (str.equals("-")) {
                value = pop2 - pop1;
            } else if (str.equals("*")) {
                value = pop2 * pop1;
            } else {
                value = pop2 / pop1;
            }
            return value;
        }


        private double result;


        public double getResult() {
            return result;
        }


        public void setResult(double result) {
            this.result = result;
        }


        private int state;


        public int getState() {
            return state;
        }


        public void setState(int state) {
            this.state = state;
        }


        public void countHouzhui(List<String> list) {
            str = new StringBuilder("");
            state = 0;
            result = 0;
            Stack<Double> stack = new Stack<Double>();
            for (String str : list) {
                int flag = this.matchWitch(str);
                switch (flag) {
                    case 3:
                    case 4:
                    case 5:
                    case 6:
                        Double pop1 = stack.pop();
                        Double pop2 = stack.pop();
                        Double value = this.singleEval(pop2, pop1, str);
                        stack.push(value);
                        break;
                    default:
                        Double push = Double.parseDouble(str);
                        stack.push(push);
                        break;
                }
            }
            if (stack.isEmpty()) {
                state = 1;
            } else {
                result = stack.peek();
                str.append(stack.pop());
            }




        }


        public void eval() throws Exception {
            List<String> list = new ArrayList<String>();
            //匹配运算符、括号、整数、小数,注意-和*要加\\
            Pattern p = Pattern.compile("[+\\-/\\*()]|\\d+\\.?\\d*");
            Matcher m = p.matcher(s1);
            while (m.find()) {
                list.add(m.group());
            }
            List<String> afterList = this.midToAfter(list);
            this.countHouzhui(afterList);
        }




    }




}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cf_matinal

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值