Donric

第一次作业-四则运算生成程序

这个作业属于哪个课程 AHPU-软件工程导论-计算机18级
这个作业要求在哪里 个人作业-四则运算题目生成程序
这个作业的目标 熟练使用markdown语法攥写博客,对题目需求进行分析并实现
学号 3181002122

一、题目要求

写一个能自动生成小学四则运算题目的程序,然后在此基础上扩展:

1)除了整数以外,还要支持真分数的四则运算,例如:1/6+1/8=7/24

2)程序要求能处理用户的输入,判断对错,累积分数

3)程序支持可以由用户自行选择加、减、乘、除运算

4)使用-n参数控制生成题目的个数,例如Myapp.exe -n 10,将生成10个题目

二、代码提交

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>
using namespace std;

// 定义一个分式结构体
typedef struct{										
	int top; 
	int bottom;
} fraction;

int maxDivisor(int m, int n);
void reductionFraction(int &m, int &n);
void add(int num,fraction computerFracAns[],int computerIntAns[]);
void subtract(int num, fraction computerFracAns[], int computerIntAns[]);
void multiply(int num, fraction computerFracAns[], int computerIntAns[]);
void divide(int num, fraction computerFracAns[]);


int main(){ 
		// 分数情况下,计算机的答案以及用户的答案 
		fraction computerFracAns[1000], userFracAns[1000];
		// 整数情况下,计算机的答案以及用户的答案
		int computerIntAns[1000] = { 0 }, userIntAns[1000] = { 0 };
		int check;
		char c; 
		int num, score = 0;
		cout<<"四则运算题目生成程序"<<endl;
		cout<<"请选择:"<<endl;
		cout<<"1:加法"<<endl;
		cout<<"2:减法"<<endl; 
		cout<<"3:乘法"<<endl; 
		cout<<"4:除法"<<endl;  
		cin>>check;  // 选择运算方式 
		cout<<"请输入题目数量:";
		cin>>num;										
		switch (check){
			case 1:add(num, computerFracAns, computerIntAns); break;
			case 2:subtract(num, computerFracAns, computerIntAns); break;
			case 3:multiply(num, computerFracAns, computerIntAns); break;
			case 4:divide(num, computerFracAns); break;
		}
		if (check == 4){  // 题目是否为除法分类讨论,分别有不同的处理方案											
			for (int i = 0; i < num; i++){
				cout<<"第"<<i+1<<"道题的答案为:";
				if (computerFracAns[i].bottom == 1){
					cin>>userFracAns[i].top;
					userFracAns[i].bottom = 1;
				}
				else
					cin>>userFracAns[i].top>>c>>userFracAns[i].bottom;
			}
		}
		else{
			for (int i = 0; i <= num / 2; i++){
				cout<<"第"<<i+1<<"道题的答案为:";
				cin>>userIntAns[i];
			}
			for (int i = num / 2 + 1; i < num; i++){ 
				cout<<"第"<<i+1<<"道题的答案为:";
				if (computerFracAns[i].bottom == 1){
					cin>>userFracAns[i].top;
					userFracAns[i].bottom = 1;
				}
				else 
					cin>>userFracAns[i].top>>c>>userFracAns[i].bottom;
			}
		}
		
		// 比较运算结果,正确则得分加1 
		for (int i = 0; i <= num / 2; i++)		
			if (userIntAns[i] == computerIntAns[i])
				score++;
				
		for (int i = num / 2 + 1; i < num; i++)
			if (userFracAns[i].top == computerFracAns[i].top && userFracAns[i].bottom == computerFracAns[i].bottom)
				score++;
				
		cout<<"成绩为:"<<score<<endl;
	 return 0;
}


// 求最大公约数 
int maxDivisor(int m, int n){							
	if (n == 0) 
		return m;
	return 
		maxDivisor(n, m % n);
}

// 对分数进行约分,不输出参数 
void reductionFraction(int &m, int &n){					
	int p = maxDivisor(abs(m), abs(n));
	m /= p;
	n /= p;
}	

// 对分数进行约分,输出参数 
void reductionFractionOutput(int &m, int &n){					
	int p = maxDivisor(abs(m), abs(n));
	m /= p;
	n /= p;
	if (n == 1)
		cout<<m;
	else
		cout<<m<<"/"<<n;
}	

// 生成加法题目 
void add(int num,fraction computerFracAns[],int computerIntAns[]){					
	int m, n = 0; 
	int top1, bottom1 = 0;
	int top2, bottom2 = 0;
	// 一半题目为整数运算,一半题目为分数运算 
	for (int i = 0; i <=num / 2; i++){
		unsigned int times = (unsigned int)time(0);  // 使用time生成随机数 
		srand(times * (i + 1));
		m = rand() % 10 + 1;
		n = rand() % 10 + 1;
		computerIntAns[i] = m + n;
		cout<<m<<"+"<<n<<endl;  //输出整数题目
	}
	for (int i = num/2+1; i < num; i++){
		unsigned int times = (unsigned int)time(0);  // 使用time生成随机数
		srand(times * (i + 1));
		top1 = rand() % 10 + 1;
		bottom1 = rand() % 10 + 1;
		top2 = rand() % 10 + 1;
		bottom2 = rand() % 10 + 1;
		reductionFractionOutput(top1, bottom1);
		cout<<"+";
		reductionFractionOutput(top2, bottom2);
		cout<<endl;										
		computerFracAns[i].top = top1 * bottom2 + top2 * bottom1;				
		computerFracAns[i].bottom = bottom1 * bottom2;												
		reductionFraction(computerFracAns[i].top, computerFracAns[i].bottom);

	}
}

// 生成减法题目 
void subtract(int num, fraction computerFracAns[], int computerIntAns[]){
	int m, n = 0; 
	int top1, bottom1 = 0;
	int top2, bottom2 = 0;
	// 一半题目为整数运算,一半题目为分数运算 
	for (int i = 0; i <= num / 2; i++){
		unsigned int times = (unsigned int)time(0);  // 使用time生成随机数
		srand(times * (i + 1));
		m = rand() % 10 + 1;
		n = rand() % 10 + 1;
		computerIntAns[i] = m - n;
		cout<<m<<"-"<<n<<endl;
	}
	for (int i = num / 2 + 1; i < num; i++){
		unsigned int times = (unsigned int)time(0);  // 使用time生成随机数
		srand(times * (i + 1));
		top1 = rand() % 10 + 1;
		bottom1 = rand() % 10 + 1;
		top2 = rand() % 10 + 1;
		bottom2 = rand() % 10 + 1;
		reductionFractionOutput(top1, bottom1);
		cout<<"-";
		reductionFractionOutput(top2, bottom2);
		cout<<endl;
		computerFracAns[i].top = top1 * bottom2 - top2 * bottom1;
		computerFracAns[i].bottom = bottom1 * bottom2;
		reductionFraction(computerFracAns[i].top, computerFracAns[i].bottom);
	}
}

// 生成乘法题目 
void multiply(int num, fraction computerFracAns[], int computerIntAns[]){
	int m, n = 0; 
	int top1, bottom1 = 0;
	int top2, bottom2 = 0;
	// 一半题目为整数运算,一半题目为分数运算 
	for (int i = 0; i <= num / 2; i++){
		unsigned int times = (unsigned int)time(0);  // 使用time生成随机数
		srand(times * (i + 1));
		m = rand() % 10 + 1;
		n = rand() % 10 + 1;
		computerIntAns[i] = m * n;
		cout<<m<<"*"<<n<<endl;
	}
	for (int i = num / 2 + 1; i < num; i++){
		unsigned int times = (unsigned int)time(0);  // 使用time生成随机数
		srand(times * (i + 1));
		top1 = rand() % 10 + 1;
		bottom1 = rand() % 10 + 1;
		top2 = rand() % 10 + 1;
		bottom2 = rand() % 10 + 1;
		reductionFractionOutput(top1, bottom1);
		cout<<"*";
		reductionFractionOutput(top2, bottom2);
		cout<<endl;
		computerFracAns[i].top = top1 * top2;
		computerFracAns[i].bottom = bottom1 * bottom2;
		reductionFraction(computerFracAns[i].top, computerFracAns[i].bottom);
	}
}

// 生成除法题目 
void divide(int num, fraction computerFracAns[]){					
	int top1, bottom1 = 0;
	int top2, bottom2 = 0;
	// 在除法下,题目无需考虑整数情况,因为此情况下他就会有除法存在就是分数了 
	for (int i = 0; i < num; i++){
		unsigned int times = (unsigned int)time(0);  // 使用time生成随机数
		srand(times * (i + 1));
		top1 = rand() % 10 + 1;
		bottom1 = rand() % 10 + 1;
		top2 = rand() % 10 + 1;
		bottom2 = rand() % 10 + 1;
		reductionFractionOutput(top1, bottom1);
		cout<<"/";
		reductionFractionOutput(top2, bottom2);
		cout<<endl;
		computerFracAns[i].top = top1 * bottom2;
		computerFracAns[i].bottom = bottom1 * top2;
		reductionFraction(computerFracAns[i].top, computerFracAns[i].bottom);
	}
}

三、运行截图

加法算式生成:


减法算式生成:

乘法算式生成:

除法算式生成:

四、个人小结

psp2.1 任务内容 计划完成需要的时间(min) 实际完成需要的时间(min)
Planning 计划 30 50
Estimate 估计这个任务需要多少时间,并规划大致工作步骤 10 5
Development 开发 355 300
Analysis 需求分析(包括学习新技术) 20 25
Design Spec 生成设计文档 15 10
Design Review 设计复审 10 10
Coding Standard 代码规范 20 15
Design 具体设计 30 25
Coding 具体编码 180 150
Code Review 代码复审 15 10
Test 测试(自我测试,修改代码,提交修改) 10 15
Reporting 报告 20 15
Test Report 测试报告 15 10
Size Measurement 计算工作量 10 10
Postmortem & Process Improvement Plan 事后总结,并提出过程改进计划 10 15

收获

这是我第一次在博客园书写我的第一篇博客,之前都是经常使用csdn,两者的markdown编辑器比较起来,csdn上有更多的可视化选项
,而博客园更多是要自己编写语法。本次博客是软件工程课程一次题目作业,根据题目的要求进行对应的编程,整个过程也是对之前学习的知识的一次巩固,还是很值得的。后面还第一次接触到了psp表,然后我也根据要求对我的整个开发历程进行了一个大概统计,也对我自己整个开发历程做一个简单的回顾,还是比较好的。

posted on 2020-11-08 21:59  Donric  阅读(186)  评论(0编辑  收藏  举报

导航