java常见问题(三)

 

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, "这是一个提示框");

                                                                                 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

高二的笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值