一个小学生练习题 能实现基本的加减乘除

2024-04-07 12:32

本文主要是介绍一个小学生练习题 能实现基本的加减乘除,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


设计一个程序,用来实现帮助小学生进行算术运算练习,它具有以下功能:
(1) 提供10道加、减、乘、除四种基本算术运算的题目,每道题中的操作数是随机产生的;
(2) 加减是100以内的数;乘除为乘法表里的;被减数大于减数;除法要求能整除;被乘数小与乘数;(若不合格重新产生)
(3) 练习者根据显示的题目输入自己的答案,程序自动判断输入的答案是否正确并显示出相应的信息。最后显示做对了几道题;

(4) 每次答题要记录做错的题目,下次做题可选择上次做错的题;

#include<iostream>
#include<stdio.h>
#include<cstdlib>
#include<time.h>
#define N 10
using namespace std;
struct math
{int i;int a,b;char op;int result;int ans;bool test; struct math *next;
};
struct math *creat()
{	int j;struct math *head, *p1, *p2;srand(time(0));head=p2=(struct math *)malloc(sizeof(struct math));for(int i=0; i<N; i++){	j=rand()%4;p1=(struct math *)malloc(sizeof(struct math));switch(j){case 1: p1->op='+';p1->a=rand()%100;p1->b=rand()%100;p1->result=p1->a+p1->b;break;case 2: p1->op='-';p1->a=rand()%100;p1->b=rand()%100;while(p1->a<p1->b)p1->a=rand()%100;p1->result=p1->a-p1->b;break;case 3: p1->op='x';p1->a=rand()%10;p1->b=rand()%10;while(p1->a<p1->b)p1->a=rand()%10;p1->result=p1->a*p1->b;break;default : p1->op='/';p1->b=rand()%10;p1->a=(rand()%10)*p1->b;p1->result=p1->a/p1->b; break;	}p2->next=p1;p2=p1;}	p1->next=NULL;return head;
}
void baocun(struct math *head)
{FILE *fp;struct math *p;p=head->next;if((fp=fopen("tian.txt","w"))==NULL){cout<<"open error"<<endl;exit(0);}else while(p!=NULL){	if(fwrite(p,sizeof(struct math),1,fp)!=1)printf("error\n");elsep=p->next;}//printf("保存成功!\n");fclose (fp);	
}
struct math *read (struct math *head)
{FILE *fp;struct math *p1,*p2;if((fp=fopen("tian.txt","r"))==NULL){printf("tttttttttttttttttttt\n");printf("error\n");exit (0);}	p2=head=(struct math *)malloc(sizeof(struct math));p1=(struct math *)malloc(sizeof(struct math));head->next=p1;while(fread(p1,sizeof(struct math),1,fp)==1){p2->next=p1;p2=p1;p1=(struct math *)malloc(sizeof (struct math));}p1->next=NULL;fclose(fp);return head;
}	
void test()
{struct math *p,*head;int i=1;int x;int count=0;cin>>x;switch(x){case 1: head=creat();p=head->next;while(p!=NULL){p->i=i;cout<<"第"<<p->i<<"道题:"<<p->a<<p->op<<p->b<<"=";cin>>p->ans;if(p->ans==p->result){cout<<"正确!"<<endl;				count++;p->test=true;}else {cout<<"错误!"<<endl;p->test=false;}p=p->next;i++;}cout<<N<<"道题做对了"<<count<<"道"<<endl;baocun(head);break;case 2:	head=read(head);p=head->next;while(p!=NULL){if(p->test==false){cout<<"第"<<p->i<<"道题:"<<p->a<<p->op<<p->b<<"=";cin>>p->ans;if(p->ans==p->result){cout<<"正确!"<<endl;p->test=true;	}else {cout<<"错误!"<<endl;p->test=false;count++;}	}p=p->next;} if(count==0){cout<<"全部都答对了!"<<endl;}elsecout<<"还有"<< count<<"道没答对"<<endl;baocun(head);break;case 3: exit(0);}
}
void menu()
{cout<<" 小学生练习题"<<endl;cout<<"1. 开始练习"<<endl;cout<<"2. 练习错题"<<endl;cout<<"3. 退出程序"<<endl; cout<<"选择执行的命令"<<endl;
}
int main()
{while(1){menu();test();	}	return 0;	 
}

运行主界面为


可以随机产生十道题,做错的题目可以下次通过练习错题来继续做。



                                    

这篇关于一个小学生练习题 能实现基本的加减乘除的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/882599

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

dp算法练习题【8】

不同二叉搜索树 96. 不同的二叉搜索树 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 示例 1: 输入:n = 3输出:5 示例 2: 输入:n = 1输出:1 class Solution {public int numTrees(int n) {int[] dp = new int