口算练习题(字符串)

作者 洛谷

单位 重庆科技学院

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

输入格式:

第一行为数值i

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

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

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

输出格式:

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

输入样例:

在这里给出一组输入。例如:

复制代码
4
a 64 46
275 125
c 11 99
b 46 64

输出样例:

在这里给出相应的输出。例如:

复制代码
64+46=110
9
275+125=400
11
11*99=1089
10
46-64=-18
9

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

栈限制

8192 KB

首先在这里介绍本题需要用到的三个新的函数:

1)<ctype.h> -->isalpha(在本题中主要用判断字母)

|---|----------------------------------------------------------------------------------------------------------------------------|
| 1 | int isalnum(int c) 该函数检查所传的字符是否是字母和数字。 |
| 2 | int isalpha(int c) 该函数检查所传的字符是否是字母。 |
| 3 | int iscntrl(int c) 该函数检查所传的字符是否是控制字符。 |
| 4 | int isdigit(int c) 该函数检查所传的字符是否是十进制数字。 |

详细用法请参考:C 标准库 -- <ctype.h> | 菜鸟教程

2)<stdlib.h> -->atoi(在本题中主要用于将字符转换为数字)

C 库函数 int atoi(const char *str) 把参数 str 所指向的字符串转换为一个整数(类型为 int 型)。

详细用法请参考:C 库函数 -- atoi() | 菜鸟教程

3)sprintf(在本题中主要用于计算运算式的总长度)

C 库函数 int sprintf(char *str, const char *format, ...) 发送格式化输出到 str 所指向的字符串。

此函数可以用于连接如下图:

详细用法请参考:C 库函数 -- sprintf() | 菜鸟教程

C程序如下:

cs 复制代码
#include<stdio.h>
#include<ctype.h>
#include<stdlib.h>
#include<string.h>

int main(void)
{
    int times, x, y;//定义算数的次数times,和参与计算的两个数x,y
    scanf("%d", &times);
    for(int i = 0; i < times; i++){
        char s[10], k;
        scanf(" %s", s);//添加空格以跳过任何前导空白
        if(isalpha(s[0])){//判断输入的第一个字符是不是字母
            k = s[0];//存储这个字母
            scanf("%d%d", &x, &y);
        }
        else{
            x = atoi(s);将字符串转换为一个整数
            scanf("%d", &y);
        }
        char cnt[200];
        if(k == 'a'){
            sprintf(cnt, "%d+%d=%d", x, y, x + y);
        }//sprintf用来链接以此来计算计算题的长度
        else if(k == 'b'){
            sprintf(cnt, "%d-%d=%d", x, y, x - y);
        }
        else{
            sprintf(cnt, "%d*%d=%d", x, y, x * y);
        }
        printf("%s\n%d\n", cnt, strlen(cnt));
    }
    return 0;
}
相关推荐
天天爱吃肉82181 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
zh_xuan1 小时前
kotlin lazy委托异常时执行流程
开发语言·kotlin
alphaTao1 小时前
LeetCode 每日一题 2026/2/2-2026/2/8
算法·leetcode
甄心爱学习1 小时前
【leetcode】判断平衡二叉树
python·算法·leetcode
阿猿收手吧!1 小时前
【C++】string_view:高效字符串处理指南
开发语言·c++
颜酱2 小时前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
不知名XL2 小时前
day50 单调栈
数据结构·算法·leetcode
玄同7652 小时前
我的 Trae Skill 实践|使用 UV 工具一键搭建 Python 项目开发环境
开发语言·人工智能·python·langchain·uv·trae·vibe coding
2401_858936882 小时前
【Linux C 编程】标准 IO 详解与实战:从基础接口到文件操作实战
linux·c语言
@––––––2 小时前
力扣hot100—系列2-多维动态规划
算法·leetcode·动态规划