P1957 口算练习题(洛谷)

本文描述了一个编程任务,要求通过编写程序自动处理简单的算术运算,包括加法、减法和乘法,输入只需运算数,输出包括完整算式、结果和总长度。使用Java中的Scanner类处理输入,展示了如何根据运算类型执行相应的计算并格式化输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


题目描述

王老师正在教简单算术运算。细心的王老师收集了 i道学生经常做错的口算题,并且想整理编写成一份练习。 编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效率。王老师希望尽量减少输入的工作量,比如5+8 的算式最好只要输入 5和8,输出的结果要尽量详细以方便后期排版的使用,比如对于上述输入进行处理后输出 5+8=13 以及该算式的总长度 6 。王老师把这个光荣的任务交给你,请你帮他编程实现以上功能。

输入格式

第一行一个整数 i。

接着的 $i$ 行为需要输入的算式,每行可能有三个数据或两个数据。

若该行为三个数据则第一个数据表示运算类型,a 表示加法运算,b 表示减法运算,c 表示乘法运算,接着的两个数据表示参加运算的运算数。

若该行为两个数据,则表示本题的运算类型与上一题的运算类型相同,而这两个数据为运算数。

 输出格式

输出 2*i 行。对于每个输入的算式,输出完整的运算式及结果,第二行输出该运算式的总长度。

样例 #1

样例输入 #1
4
a 64 46
275 125
c 11 99
b 46 64

样例输出 #1
64+46=110
9
275+125=400
11
11*99=1089
10
46-64=-18
9

提示

【数据规模与约定】

对于 50% 的数据,输入的算式都有三个数据,第一个算式一定有三个数据。

对于所有数据,0<i<=50,运算数为非负整数且小于 10000。


本题主要关键点在如何解决输入时每行数据不同的问题

字符串的输入可以使用next()和nextLine()两种

next()会自动地消除有效字符之前的空格,只返回输入的字符,不会得到带空格的字符串。

nextLine()返回的是Enter键之前的所有字符,它是可以得到带空格的字符串的。

本题每行的输入之间用空格隔开,刚好可以使用nextLine()

这样的话我们无需再考虑输入个数的问题

之后的问题就简单多了


代码如下



import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        int i=sc.nextInt();
        int result;
        char c='+';
        for (int j = 0; j < i; j++) {
            int count=2;
            String s=sc.next();
            int arr[]=new int[2];
            char x[]=s.toCharArray();
            if(x[0]>='a'&&x[0]<='c')
                count = 3;
            for (int k = 0; k < count-1; k++) {
                 arr[k]=sc.nextInt();
            }
            if(s.charAt(0)=='a') {
                c='+';
                result = arr[0] + arr[1];
                System.out.println(arr[0]+"+"+arr[1]+"="+result);
                System.out.println(length(arr[0])+length(arr[1])+length(result)+2);
            }
            else if(s.charAt(0)=='b'){
                c='-';
                result=arr[0]-arr[1];
                System.out.println(arr[0]+"-"+arr[1]+"="+result);
                System.out.println(length(arr[0])+length(arr[1])+length(result)+2);
            }
            else if(s.charAt(0)=='c') {
                c='*';
                result = arr[0] * arr[1];
                System.out.println(arr[0]+"*"+arr[1]+"="+result);
                System.out.println(length(arr[0])+length(arr[1])+length(result)+2);
            }
            else {
                int sum=s.charAt(0)-'0';
                for (int m = 0; m < x.length-1; m++) {
                    sum=10*sum+s.charAt(m+1)-'0';
                }
                if(c=='+') {
                    result = sum + arr[0];
                    System.out.println(sum+"+"+arr[0]+"="+result);
                }
                else if(c=='-') {
                    result = sum - arr[0];
                    System.out.println(sum+"-"+arr[0]+"="+result);
                }
                else {
                    result = sum * arr[0];
                    System.out.println(sum+"*"+arr[0]+"="+result);
                }
                System.out.println(x.length+length(arr[0])+length(result)+2);
            }
        }
    }
    public static int length(int x){
        int count=1;
        if(x<0){x=-x;count++;}
        while(x>9){
            x/=10;
            count++;
        }
        return count;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值