口算练习题(字符串处理)#洛谷

文章描述了一位教师如何利用编程技术简化口算题的编排过程,通过输入最少的数据,自动生成详细的算式和结果,以及总长度,以提高工作效率。

题目描述

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

输入格式

第一行为数值 iii

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

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

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

输出格式

输出 2×i2\times i2×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%50\%50% 的数据,输入的算式都有三个数据,第一个算式一定有三个数据。

对于所有数据,0<i≤500<i\leq 500<i50,运算数为非负整数且小于 100001000010000

def data_findd(srt):
    data1=[]
    data2=[]
    flag1=True
    flag2=False
    for item in srt:
        if item!=' ' and flag1:
            data1.append(item)
            pass
        if item!=' ' and flag2:
            data2.append(item)
            pass
        if item==' ':
            flag1=False
            flag2=True
            pass
        pass
    value1=int("".join(data1))
    value2=int("".join(data2))
    return value1,value2

if __name__ == "__main__":
    num = int(input())
    flaga = False
    flagb = False
    flagc = False
    for item in range(num):
        data = str(input())
        if data[0] == 'a':
            flaga = True
            flagb = False
            flagc = False
            key = []
            for jtem in range(2, len(data)):
                key.append(data[jtem])
                pass
            final = "".join(key)
            value1, value2 = data_findd(final)
            pass
        elif data[0] == 'b':
            flagb = True
            flaga = False
            flagc = False
            key = []
            for jtem in range(2, len(data)):
                key.append(data[jtem])
                pass
            final = "".join(key)
            value1, value2 = data_findd(final)
            pass
        elif data[0] == 'c':
            flagc = True
            flagb = False
            flaga = False
            key = []
            for jtem in range(2, len(data)):
                key.append(data[jtem])
                pass
            final = "".join(key)
            value1, value2 = data_findd(final)
            pass
        else:
            value1, value2 = data_findd(data)
            pass
        ph1 = str(value1)
        ph2 = str(value2)
        summ = 0
        method = ''
        if flaga:
            summ = value1 + value2
            method = '+'
            pass
        if flagb:
            summ = value1 - value2
            method = '-'
            pass
        if flagc:
            summ = value1 * value2
            method = '*'
            pass
        summ = str(summ)
        length = len(summ) + len(ph1) + len(ph2) + 2
        print(value1, end='')
        print(method, end='')
        print(value2, end='=')
        print(summ)
        print(length)

要交报告了,下午一直在看论文,趁着吃饭前做一道。字符串处理的一道题目,对于输入数据要进行处理,要判断每次的输入中是否含有字母,有字母的要记录下后在将字母去除,然后再对剩下的字符串进行分割,没有字母的则直接进行分割。注意整个用法中,没有使用列表的格式,用到列表的地方要最后转换为字符串。再就是注意abc三种情况的记录,每一次更改状态的同时也要对另外两种情况进行更改

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

直接AC好吗

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

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

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

打赏作者

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

抵扣说明:

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

余额充值