基本信息
源码名称:AndroidStudio之计算器(入门级)
源码大小:12.98M
文件格式:.zip
开发语言:Flash
更新时间:2019-06-25
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 1 元 
   源码介绍

package com.example.dell.calculator;


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

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    //这里只能加声明,并不能使用函数
    EditText output;
    Button id0;
    Button id1;
    Button id2;
    Button id3;
    Button id4;
    Button id5;
    Button id6;
    Button id7;
    Button id8;
    Button id9;
    Button jia;
    Button jian;
    Button chen;
    Button chu;
    Button del;
    Button clear;
    Button cal;
    boolean clear_flag ;//清空标识
    iStack s1=new iStack(); //s1是值栈,s2是符号栈
    cStack s2=new cStack();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        output=(EditText)findViewById(R.id.output);
        id0=(Button)findViewById(R.id.id0);
        id1=(Button)findViewById(R.id.id1);
        id2=(Button)findViewById(R.id.id2);
        id3=(Button)findViewById(R.id.id3);
        id4=(Button)findViewById(R.id.id4);
        id5=(Button)findViewById(R.id.id5);
        id6=(Button)findViewById(R.id.id6);
        id7=(Button)findViewById(R.id.id7);
        id8=(Button)findViewById(R.id.id8);
        id9=(Button)findViewById(R.id.id9);
        jia=(Button)findViewById(R.id.jia);
        jian=(Button)findViewById(R.id.jian);
        chen=(Button)findViewById(R.id.chen);
        chu=(Button)findViewById(R.id.chu);
        del=(Button)findViewById(R.id.del);
        clear=(Button)findViewById(R.id.clear);
        cal=(Button)findViewById(R.id.cal);

        id0.setOnClickListener(this);   //为此,我的类加了个接口
        id1.setOnClickListener(this);
        id2.setOnClickListener(this);
        id3.setOnClickListener(this);
        id4.setOnClickListener(this);
        id5.setOnClickListener(this);
        id6.setOnClickListener(this);
        id7.setOnClickListener(this);
        id8.setOnClickListener(this);
        id9.setOnClickListener(this);
        jia.setOnClickListener(this);
        jian.setOnClickListener(this);
        chen.setOnClickListener(this);
        chu.setOnClickListener(this);
        clear.setOnClickListener(this);
        del.setOnClickListener(this);
        cal.setOnClickListener(this);
    }

    @Override
    public void onClick(View v) {
        String str=output.getText().toString();
        switch(v.getId()) {
            case R.id.jia:
            case R.id.jian:
            case R.id.chen:
                case R.id.chu:
                int len=str.length();
                if(len!=0)
                {
                    char lastcode=str.charAt(len-1);
                    if(lastcode<48||lastcode>57)
                        str=str.substring(0,len-1);
                }
            case R.id.id0:
            case R.id.id1:
            case R.id.id2:
            case R.id.id3:
            case R.id.id4:
            case R.id.id5:
            case R.id.id6:
            case R.id.id7:
            case R.id.id8:
            case R.id.id9:
                str=str ((Button)v).getText();
                output.setText(str);
                break;
            case R.id.clear:
                str="";
                output.setText(str);
                break;
            case R.id.del:
                if (clear_flag) {
                    clear_flag =false ;
                    str ="" ;
                    output.setText("");
                }else if (str!=null&&!str.equals("")){
                    output.setText(str.substring(0,str.length()-1));
                }
                break;
            case R.id.cal:
                getAns();
                break;
        }
    }
    public void getAns()
    {
        String str=output.getText().toString() '#';
        int len=str.length();
        if(len==1)return;
        if(str.charAt(0) < 48 || str.charAt(0) > 57)
        {
            str=str.substring(1,len-1);
            output.setText(str);
            return;
        }
        if(str.charAt(len-2) < 48 || str.charAt(len-2) > 57)
        {
            str=str.substring(0,len-2);
            output.setText(str);
            return;
        }
        s2.push('#');
        int n=0;    //n是表示扫描到的数字值为多少,初始化为0
        boolean book=false; //没办法,用来当做n取值的有效值,true有效
        for(int i=0;i<len;i  ) {
            char c = str.charAt(i);
            if (c >= 48 && c <= 57) {
                n = n * 10   c - 48;
                book = true;
            } else if (c == ' ' || c == '-' || c == '*' || c == '/' || c == '#' ) {
                if (book == true) {
                    s1.push(n); //遇到符号就入栈,并清零
                    n = 0;
                    book = false;
                }
                if (compare(c)) {    //如果当前优先级要低就开始计算
                    int n2 = s1.top();    //3 5,则n1为3,n2为5
                    s1.pop();
                    ;
                    int n1 = s1.top();
                    s1.pop();
                    ;
                    char op = s2.top();
                    s2.pop();
                    int ans = 0;
                    switch (op) {
                        case ' ':
                            ans = n1   n2;
                            break;
                        case '-':
                            ans = n1 - n2;
                            break;
                        case '*':
                            ans = n1 * n2;
                            break;
                        case '/':
                            ans = n1 / n2;
                            break;
                    }
                    s1.push(ans);
                    i--;    //下一轮继续比
                } else {
                    s2.push(c);
                }
            }
            else {
                output.setText("");
                return;
            }
        }
        str=s1.top() "";
        output.setText(str);
        s1.clear();
        s2.clear();
    }
    boolean compare(char t)
    {
        int n1,n2;      //n1是栈顶的优先级,n2是当前扫到符号的优先级,#为0, 、-为1,*、/为2
        if(t=='*'||t=='/')n2=2;
        else if(t==' '||t=='-') n2=1;
        else n2=0;
        t=s2.top();
        if(t=='*'||t=='/')n1=2;
        else if(t==' '||t=='-') n1=1;
        else n1=0;
        return n2<n1;   //当前符号优先级小于栈顶元素的时候开始计算
    }
}
class iStack{
    private int value[]=new int[100];
    private int top;
    iStack()
    {
        top=-1;
    }
    public void push(int c)
    {
        value[  top]=c;
    }
    public void pop()
    {
        top--;
    }
    public boolean empty()
    {
        return top==-1?true:false;
    }
    public void clear()
    {
        top=-1;
    }
    public int top()
    {
        return value[top];
    }
};
class cStack{
    private char value[]=new char[100];
    private int top;
    cStack()
    {
        top=-1;
    }
    public void push(char c)
    {
        value[  top]=c;
    }
    public void pop()
    {
        top--;
    }
    public boolean empty()
    {
        return top==-1?true:false;
    }
    public void clear()
    {
        top=-1;
    }
    public char top()
    {
        return value[top];
    }
};