团队:

郭志豪:http://www.cnblogs.com/gzh13692021053/

杨子健:http://www.cnblogs.com/yzj666/

刘森松:http://www.cnblogs.com/lssh/

谭宇森:http://www.cnblogs.com/dalaotan/

GITHUB地址:https://github.com/Sub-key/1/tree/master/app

app功能实现

                       

主要类代码:

CaculateEx.class源代码以及说明如下:

package com.lsf.cal.calc;

import java.util.Stack;

public class CaculateEx {

public String suffix_expression(String expression)//中缀表达式转换后缀表达式(逆波兰式)

{

//Stack<Double> s2=new Stack<Double>();//存放数字栈

Stack<Object> s3=new Stack<Object>();//存放结果栈

Stack<Character> s4=new Stack<Character>();//存放操作符栈

int len=expression.length();//

char c1;

double number;

int m,n=-1;

for(int i=0;i<len;i++)

{

c1=expression.charAt(i);

if(isOprator(c1)||(i==len-1))//如果是运算符,将前面的数数字入s3栈,操作符入s4栈

{

if(i==len-1&&(!isOprator(c1)))//当最后一位且不是操作符时,将前面的数压栈

m=i+1;

else

m=i;

//操作数入栈,向前遍历到下一个运算符,将中间的字符串转化为double

for(int j=i-1;j>=0;j--)

{

if(isOprator(expression.charAt(j)))

{

n=j;

break;

}

n=j-1;

}

if(m!=n+1)//只有当这两个值不等时中间才会有操作数

{

number=Double.parseDouble(expression.substring(n+1,m));

s3.push(number);

}

//运算符入栈

if(i==0&&(c1!='('))//当表达式第一个字符就为运算符且不是左括号时,返回表达式错误

{

return "表达式错误!";

}

else if(isOprator(c1))//且是操作符时

{

while(true)

{

if(s4.isEmpty()||s4.peek()=='('||c1=='(')//如果栈为空或者栈顶元素为(或者c1为(时,则直接将运算符压入栈内

{

s4.push(c1);

break;

}

else if(c1==')')//当c1为)时,依次弹出s4中的运算符并压入s3,直到(,舍弃这一对括号

{

while(s4.peek()!='(')

{

s3.push(s4.pop());

if(s4.isEmpty())//弹出所有不为左括号之后堆栈为空,则表达式不合法

{

return "缺少左括号";

}

}

s4.pop();//弹出(

break;

}

else

{

if(priorityCompare(c1,s4.peek())==1)//判断优先级,优先级高入栈,优先级低将栈顶运算符压入s3

{

s4.push(c1);

break;

}

else

{

s3.push(s4.pop());

}

}

}

}

}

else

continue;

}

while(!s4.isEmpty())//表达式结束后,依次将s4剩下的运算符压入s3

{

if((char)s4.peek()=='(')

return "缺少右括号";

s3.push(s4.pop());

}

return count_result(s3);

}

private int priorityCompare(char c1,char c2)

{

switch(c1)

{

case '+':

case '-':

return (c2 == '*' || c2 == '/' ? -1 : 0);

case '*':

case '/':

return (c2 == '+' || c2 == '-' ? 1 : 0);

}

return 1;

}

//判断字符是否为运算符,是为真,不是为假

private boolean isOprator(Object c) {

// TODO Auto-generated method stub

try

{

char c1=(char)c;

if(c1=='+'||c1=='-'||c1=='*'||c1=='/'||c1=='('||c1==')')

return true;

}

catch (Exception e) {

// TODO: handle exception

return false;

}

return false;

}

private String count_result(Stack<Object> ob) {

// TODO Auto-generated method stub

Stack<Object> s1=new Stack<Object>();//后缀表达式栈

Stack<Double> s2=new Stack<Double>();//操作数栈

//char c1;

//    Stack<Character> s3=new Stack<Character>();//操作符栈

while(!ob.isEmpty())//将传入的栈逆序压入

{

s1.push(ob.pop());

}

while(!s1.isEmpty())

{

if(!isOprator(s1.peek()))//遇到非操作符,压入s2栈

{

s2.push((Double)s1.pop());

}

else

{

s2.push(cout(s2.pop(),s2.pop(),(char)s1.pop()));

}

}

return Double.toString(s2.peek());

}

private Double cout(double s1,double s2,char s3)

{

double result=0;

switch(s3)

{

case '+':

result=s1+s2;

break;

case '-':

result=s1-s2;

break;

case '*':

result=s1*s2;

break;

case '/':

result=s1/s2;

break;

}

return result;

}

}

3.2、核心类(MainActivity)

MainActivity.class源代码如下:

4、运package com.lsf.cal.calc;

import android.support.v7.app.ActionBarActivity;

import android.os.Bundle;

import android.view.Menu;

import android.view.MenuItem;

import android.view.View;

import android.widget.Button;

import android.widget.EditText;

public class MainActivity extends ActionBarActivity implements View.OnClickListener {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

Button caculateButton=(Button)findViewById(R.id.button);

caculateButton.setOnClickListener(this);

Button clearButton=(Button)findViewById(R.id.clear);

clearButton.setOnClickListener(this);

}

@Override

public void onClick(View v) {

EditText editText = (EditText) findViewById(R.id.text);

if(v.getId()==R.id.button) {

CaculateEx caculateEx = new CaculateEx();

String expreString = editText.getText().toString();

expreString = caculateEx.suffix_expression(expreString);

editText.setText(expreString);

}else{

editText.setText("");

}

}

@Override

public boolean onCreateOptionsMenu(Menu menu) {

// Inflate the menu; this adds items to the action bar if it is present.

getMenuInflater().inflate(R.menu.menu_main, menu);

return true;

}

@Override

public boolean onOptionsItemSelected(MenuItem item) {

// Handle action bar item clicks here. The action bar will

// automatically handle clicks on the Home/Up button, so long

// as you specify a parent activity in AndroidManifest.xml.

int id = item.getItemId();

//noinspection SimplifiableIfStatement

if (id == R.id.action_settings) {

return true;

}

return super.onOptionsItemSelected(item);

}

}

四则运算app代码上传GITHUB的更多相关文章

  1. git使用之如何将github库下载到本地与如何将代码上传github

    git使用之如何将github库下载到本地与如何将代码上传github ---------------------------------------------------------------- ...

  2. eclipse 代码上传github 笔记

    第一步 先share project 如图所示  第二步 如果所示  第三步 点击 下面的create 然后点击完成  第四步提交  第五步: 第六步: 

  3. 把上传Github的代码添加Cocoapods支持

    开始 这里我将从最初的开始进行介绍,包括Github上创建项目已经上传项目,到最后的支持Cocoapods. 步骤如下: 代码上传Github 创建podspec文件,并验证是否通过 在Github上 ...

  4. 一步一步实现android studio代码上传到github。

    本文只注重代码上传能成功就好,不解释什么是git什么事github,git有什么优势. 1,先创建一个android应用, 第二步:创建github账户 和 安装git.网上的文章多如牛毛.唯一要说的 ...

  5. 使用pycharm开发代码上传到GitLab和GitHub

    使用pycharm开发代码上传到GitLab和GitHub 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 我这里主要是针对局域网的自减的GitLab服务器,python开发工程师如 ...

  6. Android studio下将项目代码上传至github包括更新,同步,创建依赖

    AS中设置GIT 一.开篇 本文讲如何使用Android Studio将项目上传到github,虽然讲上传github的文章很多,但是大部分都是使用Git Bash命令行,虽然效率高些,但是有点麻烦, ...

  7. mac上将代码上传到github

    前言 有时我们会写一些小程序来学习新的知识,但是完事之后过一段时间可能会忘记,最好的办法就是找到原来的代码看一看.现在可以将代码免费托管到一些网站上,其中最著名的非github莫属了, 今天就把这个过 ...

  8. 使用git工具将本地电脑上的代码上传至GitHub

    本文教你如果使用git工具将本地电脑上的代码上传至GitHub 1.安装git工具 安装git链接 2.使用git工具上传自己的代码到GitHub中 安装完git工具之后,我们会得到两个命令行工具,一 ...

  9. mac上将代码上传到github以及github对100M以上文件限制上传的处理(lfs)。

    前言 有时我们会写一些小程序来学习新的知识,但是完事之后过一段时间可能会忘记,最好的办法就是找到原来的代码看一看.现在可以将代码免费托管到一些网站上,其中最著名的非github莫属了, 今天就把这个过 ...

随机推荐

  1. MySQL 子查询与连接操作笔记

    SQL语句之间是可以进行连接操作的,在一些复杂的数据操作中必须用到连接操作.简单的说就是一个SQL语句的结果可以作为相连接的SQL操作的一部分.SQL结构化查询语句,子查询是指的所有的SQL操作,并非 ...

  2. Id.value与document.getElementById("Id").value的区别

    如果标签Id在Form表单里面的话,直接Id.value就不能用了,而是要用Form.Id.value来取值或设置值 所以最好用document.getElementById("Id&quo ...

  3. 仅用aspx文件实现Ajax调用后台cs程序。(实例)

    仅用aspx文件实现Ajax调用后台cs无刷新程序.(实例) 两个文件:aaa.aspx 和aaa.aspx.cs 一.aaa.aspx <script type="text/java ...

  4. win7系统下 自带的定时关机

    进入cmd下,输入shutdown -s -t 600 以上例子代表的是10分钟后自动关机 -s代表定时关机 -t代表着定时,时间以秒为单位一分钟60s 输入完后按enter 定时关机设置完成 当想取 ...

  5. PSD文件在MAC上和在WINDOWS上的大小有本质区别

    因为偷懒在MAC上的美工,发我的PSD文件,我就直接在上面做了= =后来不知道为什么无论我怎么合并图层.PSD的大小永远都是107M....然后忍无可忍重新画就从107M变成2M.....MAC为什么 ...

  6. Python3.5之TuShare

    这部分是直接搬运过来的,官方网站http://tushare.waditu.com/ TuShare是一个免费.开源的python财经数据接口包.主要实现对股票等金融数据从数据采集.清洗加工 到 数据 ...

  7. C#版BitStream 1.0

    根据C++版的改编,刚刚改完,估计使用会有问题,对于uint8处理的不好 关于使用: BitStream bs = new BitStream( ); bs.WriteInt32( ); int a ...

  8. JSP复习整理(四)Cookie

    一.useCookie.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"& ...

  9. 移动端下拉刷新、加载更多插件dropload.js(基于jQuery/Zepto)[转]

    使用方法 引用css和js <link rel="stylesheet" href="../dist/dropload.min.css"> < ...

  10. NYOJ之题目1058部分和问题

    ---------------------------------------- 简单搜索+剪枝 因为考虑到可能会有多个解,所以是将中间过程保存最后才一起打印出来的 AC代码: 1: 2: impor ...