5.用堆栈实现加减乘除
用堆栈实现加减乘除,参考网上。
实现函数String compute(String input)
假设输入的是一串表达式如"1 + 2 + 3"
我们只需要对这个字符串表达式进行处理,然后根据不同的符号做不同的压栈、出栈操作即可。因为要计算表达式,所以像+2+3这样的表达式肯定要在传参前或传参后进行处理为正常的表达式。这里只写正常情况例如1+2+3。那可以认定在没碰到运算符之前的数为第一个数,这里是1,将其压栈。往下走,碰到运算符“+”则将运算符位置之后的数值继续压栈,依次类推直到整个字符串表达式遍历完。那么栈中就存在元素1 2 3。好,现在只要依次出栈并相加即可。好像看起来和直接相加是一样的结果,实则不然。因为举例的表达式是较为简单的,如碰到输入7+8*5这样存在计算优先级的表达式,堆栈就发挥作用了。我们心算时知道要先算8*5=40再加上7等于47。但是计算机不知道。所以如果遍历时发现乘法*,要先将栈顶元素出栈和乘号之后的数做乘法,再入栈。用7+8*5举例,在碰到*之前栈中元素应该是7 8当碰到乘号时,将8出栈和5做乘法得到40,再将40入栈,最后栈中元素为7 40这样再把栈中的元素依次出栈并相加即得到正确的结果47。除法也是一样的道理。因为当乘法或除法和加法或减法碰到时要先计算乘法或除法。减法也是一样的道理,只是如果碰到减法,把减法符号之后的数值取反入栈,再依次出栈并相加即可。
//测试数据时要输入1空格+空格2空格+空格3 即在运算符前后加上空格,这是为了后面方便利用分隔转化 public static double compute(String input) { String str[]; str = input.split(" ");//利用分隔将字符串转化为字符串数组 Stack<Double> s = new Stack<Double>(); double m = Double.parseDouble(str[0]);// 第一个为数字,奇数为运算符,偶数为操作数 s.push(m); for (int i = 1; i < str.length; i++) { if (i % 2 == 1) { if (str[i].compareTo("+") == 0) { double help = Double.parseDouble(str[i + 1]); s.push(help); } if (str[i].compareTo("-") == 0) { double help = Double.parseDouble(str[i + 1]); s.push(-help); } if (str[i].compareTo("*") == 0) {// 1*2 double help = Double.parseDouble(str[i + 1]); double ans = s.peek();// 取出栈顶元素 s.pop();// 消栈 ans *= help; s.push(ans); } if (str[i].compareTo("/") == 0) { double help = Double.parseDouble(str[i + 1]); double ans = s.peek(); s.pop(); ans /= help; s.push(ans); } if (str[i].compareTo("%") == 0) { double help = Double.parseDouble(str[i + 1]); double ans = s.peek(); s.pop(); ans %= help; s.push(ans); } } } double ans = 0d; while (!s.isEmpty()) { ans += s.peek(); s.pop(); } return ans; }
6.根号的计算方法
刚开始怎么样也不知道根号该来怎么计算。看了一下网上的才恍然大悟。比如根号9等于3。3*3=9,4*4=16。如果想求m开根号等于多少,设n*n=m。那么我们只要用暴力搜索求n就可以了。不过如果要考虑到例如:根号5的精度问题。那么就要写一个稍复杂的暴力法。以根号5为例:我们可以先求整数部分:
public static int sq(int n){//求根函数1 if( n == 1){ return 1; } int tmp = 0; for(int i=1;i<=n/2+1;i++){ if(i*i == n){ tmp = i; break; } if(i*i > n){ tmp = i-1; break; } } return tmp; }//输入5 输出2 求出根号5的整数部分2
再写一个保留m位小数的函数
public static double[] sc(int m){//求根函数2 m==3保留三位小数 double[] arr = new double[m]; int num = 0; while(num != m){ double f = 1; for(int i=0;i<=num;i++){ f = f*10; } arr[num] = 1/f;//arr[0]=0.1 f==10、arr[1]=0.01 f==100、arr[2]=0.001 f==1000 num++; } return arr; }//输入3 保留三位小数 输出0.1 0.01 0.001
最后用一个函数将要开根的数、整数部分、小数部分结合起来
public static double sb(int n, double j, double[] arr){//求根函数3 double tmp = j; for(int p=0;p<arr.length;p++){ if(p>0){ j = tmp;//计算过后的值(整数位+小数位的和,赋值给j,下面继续运算) } for(int i=1;i<=9;i++){//小数位只有九位{0.1,0.2,0.3,0.4,0.5,0.6,0.7,0.8,0.9} tmp = i*arr[p]+j;//i*arr[p] if(tmp*tmp == n){ return tmp; } if(tmp*tmp >n){ //避免丢失精度 BigDecimal c1 = new BigDecimal(Double.toString(tmp)); BigDecimal c2 = new BigDecimal(Double.toString(arr[p])); tmp = c1.subtract(c2).doubleValue(); break; } } } return tmp; }
7.进制之间的转化
以十进制作为中间桥梁
k进制转化为10进制
//假设2进制转化为10进制,则k等于2;8进制转化为10进制时k等于8; public static int transform1(int[] m,int k) { int ans=0; for(int i=m.length-1;i>=0;i--) { for(int j=0;j<m.length-1-i;j++) m[i]*=k; ans+=m[i]; } return ans; }
十进制转化为k进制
//假设将10进制转化为16进制,则k等于16;输入10 输出A public static String transform2(String s,int k) {//k为要转化的进制数 int ans = Integer.parseInt(s); int chushu; String s1=""; Vector b=new Vector(); chushu=ans; while(chushu!=0) { if(k!=16) { b.add(chushu%k); chushu=chushu/k; }else { if(chushu%k==10||chushu%k==11||chushu%k==12||chushu%k==13||chushu%k==14||chushu%k==15) { switch(chushu%k) { case 10:b.add("A");break; case 11:b.add("B");break; case 12:b.add("C");break; case 13:b.add("D");break; case 14:b.add("E");break; case 15:b.add("F");break; } }else b.add(chushu%k); chushu=chushu/k; } } for(int i=0;i<b.size();i++) { s1+=b.get(i); } return new StringBuffer(s1).reverse().toString();//将字符串反向输出 }
8.可变长数组的使用以及vector
import java.util.ArrayList; public class gao{ public static void main(String args[]) { ArrayList<String> strArray = new ArrayList<String>(); strArray.add("1");strArray.add("2");strArray.add("3"); for(int i=0;i<strArray.size();i++) { System.out.print(strArray.get(i)); } } }//输出123
vector
import java.util.Vector; public class gao{ public static void main(String args[]) { Vector vector=new Vector(); vector.add(1);vector.add(2);vector.add(3); for(int i=0;i<vector.size();i++) { System.out.print(vector.get(i)); } } }//输出123
9.窗口属性
setLayout()//设置布局方式 setSize(600, 230);//设置窗体大小 setVisible(true);//设置窗体可见 setResizable(false);//设置窗口大小不可改变 setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);//设置窗体可关闭 setText()//设置文本框或文本域内容 getText()//获取文本框或文本域内容 setBounds(x,y,w,h)//设置窗体在桌面坐标以及大小 JOptionPane.showMessageDialog(null, "这是一个提示框");