zoukankan      html  css  js  c++  java
  • 前缀表达式

    问题描述

      编写一个程序,以字符串方式输入一个前缀表达式,然后计算它的值。输入格式为:“运算符 对象1 对象2”,其中,运算符为“+”(加法)、“-”(减法)、“*”(乘法)或“/”(除法),运算对象为不超过10的整数,它们之间用一个空格隔开。要求:对于加、减、乘、除这四种运算,分别设计相应的函数来实现。
      输入格式:输入只有一行,即一个前缀表达式字符串。
      输出格式:输出相应的计算结果(如果是除法,直接采用c语言的“/”运算符,结果为整数)。
      输入输出样例
    样例输入
    + 5 2
    样例输出
    7
     
    数据可能是两位数或者多位数,这个题可以用多种方法解决,可以回顾一下java中解析字符串的方法
    import java.util.Scanner;
    import java.util.StringTokenizer;
    
    public class Main {
    
        public static void main(String[] args) {
            //第一种方法
    
            Scanner scanner = new Scanner(System.in);
            /**
            String s = scanner.next();
            if(s.equals("+")){
                int a = Integer.parseInt(scanner.next());
                int b = Integer.parseInt(scanner.next());
                System.out.println(a+b);
            }
            else if(s.equals("-")){
                int a = Integer.parseInt(scanner.next());
                int b = Integer.parseInt(scanner.next());
                System.out.println(a-b);
            }
            else if(s.equals("*")){
                int a = Integer.parseInt(scanner.next());
                int b = Integer.parseInt(scanner.next());
                System.out.println(a*b);
            }
            else if(s.equals("/")){
                int a = Integer.parseInt(scanner.next());
                int b = Integer.parseInt(scanner.next());
                System.out.println(a/b);
            }
            */
    
            String s = scanner.nextLine();
            StringTokenizer tokenizer = new StringTokenizer(s);
            String op = tokenizer.nextToken();
            if(op.equals("+")){
                int a = Integer.parseInt(tokenizer.nextToken());
                int b = Integer.parseInt(tokenizer.nextToken());
                System.out.println(a+b);
            }
            else if(op.equals("-")){
                int a = Integer.parseInt(tokenizer.nextToken());
                int b = Integer.parseInt(tokenizer.nextToken());
                System.out.println(a-b);
            }
            else if(op.equals("*")){
                int a = Integer.parseInt(tokenizer.nextToken());
                int b = Integer.parseInt(tokenizer.nextToken());
                System.out.println(a*b);
            }
            else if(op.equals("/")){
                int a = Integer.parseInt(tokenizer.nextToken());
                int b = Integer.parseInt(tokenizer.nextToken());
                System.out.println(a/b);
            }
        }
    
    
    }
  • 相关阅读:
    BZOJ 2142: 礼物 [Lucas定理]
    HDU 4349 Xiao Ming's Hope [Lucas定理 二进制]
    HDU 3944 DP? [Lucas定理 诡异的预处理]
    HDU 3037 Saving Beans [Lucas定理]
    HDU 4372 Count the Buildings [第一类斯特林数]
    整理一点与排列组合有关的问题[组合数 Stirling数 Catalan数]
    ZOJ 3557 & BZOJ 2982 combination[Lucas定理]
    BZOJ 3790: 神奇项链 [Manacher 贪心]
    CF 2015 ICL, Finals, Div. 1 J. Ceizenpok’s formula [Lucas定理]
    HDU 1573 X问题 [中国剩余定理]
  • 原文地址:https://www.cnblogs.com/zhanghaijie/p/8511731.html
Copyright © 2011-2022 走看看