团队:

郭志豪: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. mkdir创建目录

    mkdir:make directories(创建目录) 创建目录的首要条件:在当前目录或者欲创建目录下,该用户具有写入权限,mkdir详细功能如下: 1.mkdir不接任何参数时,即mkdir di ...

  2. bind绑定参数

    const curry = (fn) => (...args)=>fn.bind(null,...args); const split = curry((splitOn, str) =&g ...

  3. MFC像窗体坐标位置发送 点击消息

    int x11=495;                                        int y22=600;                                     ...

  4. 3篇NeuroImage文献分析

    鉴于之前读的一些文章很容易就忘掉了,故打算花点时间记录下所读的文献. 这几天花了一些时间读了3篇文献: Intersubject consistency of cortical MEG signals ...

  5. DataTable常用代码

    构建DataTable DataTable dtUserInfo = new DataTable("UserInfo"); dtUserInfo.Columns.Add(" ...

  6. js算数优先级

    .fullwidth-table { background: white } .fullwidth-table>th { background: #f50 } 优先级 运算类型 关联性 运算符 ...

  7. 【webGL】threejs常用的api

    /*** 场景(scene) ***/ var scene = new THREE.Scene(); // 创建场景 scene.add(x); // 插入场景 /*** 相机(camera) *** ...

  8. vim /vi中对字符串的查找并替换

    vi/vim 中可以使用 :s 命令来替换字符串.该命令有很多种不同细节使用方法,可以实现复杂的功能,记录几种在此,方便以后查询.    :s/vivian/sky/ 替换当前行第一个 vivian ...

  9. jquery动态添加的html,第三方插件无法生效的情况

    今天一个问题纠结了半天,问题如下图  问题大致就是如上,新增的内容死活点不起,插件没有生效,在一个装逼前端群里面问,给我的答案是叫我去了解事件委托,了解一下事件冒泡!! 好吧,我一上午加半个下午的时间 ...

  10. iOS多线程笔记

    在iOS开发中,有三种多线程处理方式: 1. 利用NSThread 2. NSOperation和NSOperationQueue 3. 利用GCD(Grand Central Dispatch) 使 ...