java计算器.doc_第1页
java计算器.doc_第2页
java计算器.doc_第3页
java计算器.doc_第4页
java计算器.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

java计 算 器package jisuanqi;import java.awt.BorderLayout;import java.awt.Font;import java.awt.GridLayout;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.math.BigDecimal;import java.math.MathContext;import javax.swing.BoxLayout;import javax.swing.JButton;import javax.swing.JFrame;import javax.swing.JPanel;import javax.swing.JTextField;public class Calculator implements ActionListenerprivate JFrame body;private JPanel head;private JPanel keys;private JTextField show;private JButton clearButton;public Calculator() body = new JFrame(计算器);head = new JPanel();keys = new JPanel();public void init() body.setLayout(new BorderLayout();head.setLayout(new BoxLayout(head,BoxLayout.X_AXIS);show = new JTextField(30);head.add(show);clearButton = new JButton(C);head.add(clearButton);body.add(head,BorderLayout.NORTH);keys.setLayout(new GridLayout(4,4,6,6);String str = 123+456-789*0.=/;for (int i = 0; i str.length(); i+) JButton key = new JButton(str.charAt(i)+);key.setFont(new Font(Courier New,Font.ROMAN_BASELINE,15);key.addActionListener(this);keys.add(key);body.add(keys,BorderLayout.SOUTH);public void setStyle() show.setText(0);show.setEditable(false);show.setHorizontalAlignment(JTextField.RIGHT);public void addEventHandler() clearButton.addActionListener(new ActionListener()public void actionPerformed(ActionEvent e) show.setText(0););public void showMe() init();setStyle();addEventHandler();body.pack();body.setLocation(200, 300);body.setResizable(false);body.setVisible(true);body.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);public void actionPerformed(ActionEvent e) String cmd = e.getActionCommand();String cmds = show.getText();String str = +-*/.;String temp = ;if (0.equals(cmds) & str.indexOf(cmd) = 0 & -.equals(cmd) = false) cmd = ;/对输入是 “*/.” 进心判断if (str.indexOf(cmd) = 0) if (-.equals(cmds) cmd = ;if (.equals(cmds) = false) & str.indexOf(cmds.charAt(cmds.length()-1) =0 ) cmd = ;/对输入是.进行判断if (.equals(cmd) for (int i = cmds.length()-1; i 0 ; i-) if (.equals(cmds.charAt(i)+) cmd = ;break;if (str.indexOf(cmds.charAt(i) = 0) break;if (cmds.indexOf(=) = 0) cmd = ;cmds = 0;/对输入是=进行判断if (=.equals(cmd) if (str.indexOf(cmds.charAt(cmds.length()-1) =0) cmd = ;if (0.equals(cmds) cmd = ;/实现算术表达式if (.equals(cmd) = false) temp = cmds;int i = 0;do if (*.equals(temp.charAt(i)+) | /.equals(temp.charAt(i)+) temp = f(temp,temp.charAt(i)+);i = 0;i+;System.out.println(temp);while(i temp.length();i = 0;do if (*.equals(temp.charAt(i)+) | /.equals(temp.charAt(i)+) temp = f(temp,temp.charAt(i)+);i = 0;if (+.equals(temp.charAt(i)+) | -.equals(temp.charAt(i)+) temp = f(temp,temp.charAt(i)+);i = 0;i+;System.out.println(temp);while(i temp.length();show.setText(cmds+cmd+temp);/算术表达式方法/s是表达式字符串,c是算术符public String f(String s,String c) String str = +-*/;String temp1 = ;String temp2 = ;for (int i = 0; i = 0; m-) if (str.indexOf(s.charAt(m) =0 ) break;temp1 += s.charAt(m);/字符串倒置String temp = ;for (int j = temp1.length()-1; j = 0 ; j-) temp += temp1.charAt(j);temp1 = temp;for (int m = i+1; m =0 ) break;temp2 += s.charAt(m);if (+.equals(c)s = s.replace(temp1+temp2, (new BigDecimal(temp1).add(new BigDecimal(temp2),MathContext.DECIMAL128).toString();if (-.equals(c)s = s.replace(temp1+-+temp2, (new BigDecimal(temp1).subtract(new BigDecimal(temp2),MathContext.DECIMAL128).toString();if (*.equals(c)s = s.replace(temp1+*+temp2, (new BigDecimal(temp1).multiply(new BigDecimal(temp2),MathContext.DECIMAL128).toString();if (/.equals(c)s = s.replace(temp1+/+temp

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论