一、作业信息
| |||||||||
---|---|---|---|---|---|---|---|---|---|
二、题目要求
写一个能自动生成小学四则运算题目的程序,然后在此基础上扩展:
1)除了整数以外,还要支持真分数的四则运算,例如:1/6+1/8=7/24
2)程序要求能处理用户的输入,判断对错,累积分数
3)程序支持可以由用户自行选择加、减、乘、除运算
4)使用-n参数控制生成题目的个数,例如Myapp.exe -n 10,将生成10个题目
三、代码提交与运行截图
1、源代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void menu()
{
system("cls");
printf("**********四则运算题目生成器***********
");
printf("请选择生成的题目类型:
");
printf("1.加法运算
");
printf("2.减法运算
");
printf("3.乘法运算
");
printf("4.除法运算
");
printf("0.退出
");
printf("提示:真分数运算结果要化简!
");
printf("请输入选项(0-4):");
}
int *produce(int *eg,int num_a,int num_b)
{
int i,m,k,*a,j,t=1,v,b;
m=num_b-num_a+1;
v=m/2-1;
b=0;
a=(int *)malloc(m/2*sizeof(int));
srand(time(NULL));
while(t<=2)
{
for(j=0,i=b+1;i<=v+1;i++,j++)
{
a[j]=i;
}
for(k=0,i=b;i<=v;i++,k++)
{
j=(int) ((float) ((m/2-k)*rand())/(RAND_MAX+1.0));
eg[i]=a[j];
a[j]=a[m/2-1-k];
}
b=m/2;
v=m-1;
t++;
}
free(a);
return eg;
}
int *simplify(int *f)
{
int i;
for(i=f[0];i>1;i--)
{
if((f[0]%i==0)&&(f[1]%i==0))
{
f[0]=f[0]/i;
f[1]=f[1]/i;
i=f[0];
}
}
return f;
}
void over()
{
int i;
printf("答题结束!输入任意数字退出!
");
printf("请输入数字:");
scanf("%d",&i);
}
int main()
{
int *number_int=NULL;
int *number_f=NULL;
int i,m,k,q,w,r;
int *f1,*f2;
float answer;
float y;
int score,error;
int j;
int n;
while(1)
{
menu();
do
{
scanf("%d",&i);
if(i<0||i>4)
{
printf("输入不合法!请重新输入!
");
}
}while(i<0||i>4);
if(i!=0)
{
do
{
printf("请输入测试题目数量(题目生成数量1-50):");
scanf("%d",&n);
if(n<1||n>50)
{
printf("输入不合法!请重新输入!
");
}
}while(n<1||n>50);
j=n/3;
m=2*(n-j);
k=4*j;
number_int=(int *)malloc(m*sizeof(int));
number_f=(int *)malloc(k*sizeof(int));
number_int=produce(number_int,0,m-1);
number_f=produce(number_f,0,k-1);
f1=(int *)calloc(2,sizeof(int));
f2=(int *)calloc(2,sizeof(int));
}
switch(i)
{
case 1:
score=0;
for(q=0,w=m/2;q<=m/2-1;q++,w++)
{
answer=number_int[q]+number_int[w];
printf(" %d + %d = ",number_int[q],number_int[w]);
scanf("%d",&r);
if(r==answer)
{
score++;//得分
printf("正确!得分:%d
",score);
}
else
{
printf("错误!正确答案:%0.1f
",answer);
}
}
for(q=0,w=k/2;q<k/2-1;q++,w++)//真分数数
{
f1[0]=number_f[q];//分子
f1[1]=number_f[w];//分母
printf("%d/%d +",f1[0],f1[1]);
f1=simplify(f1);//化简
f2[0]=number_f[q+1];//分子
f2[1]=number_f[w+1];//分母
printf("%d/%d =
",f2[0],f2[1]);
f2=simplify(f2);
f1[0]=f1[0]*f2[1]+f1[