1.需求分析:

(1)自动生成四则运算算式(+ - *  /),或两则运算(+  -)。

(2)剔除重复算式。

(3)题目数量可定制。

(4)相关参数可控制。 

(5)生成的运算题存储到外部文件中。

  2.功能设计:

  • 基本功能:随机生成算式,可控制题目数量及相关参数。筛选重复的算式并剔除。
  • 拓展功能:当操作数生成负数是会产生小括号。

  3.设计实现:


  共设计了4个函数:Ctrl_2or4:用来控制四则运算还是2则运算。

          Rand_Get:生成随机数,是否包含负数可控。

          Data_Filtering:数据过滤,剔除重复算式。

          My_print:控制输出。

  4.测试运行:

1.生成四则运算,包含负数,操作数100以内,10道题:

2.生成两则运算,不包含负数,操作数50以内,15道题:

3.生成四则运算,包含负数,操作数范围1000以内,7道题:

  5.代码片段:

  • 生成随机数,控制操作数是否带负数:
 void Rand_Get(int c , int Maxl)
{
if( c == )
{
Num_a = rand()%(*Maxl+)-Maxl;
Num_b = rand()%(*Maxl+)-Maxl;
}
else if( c == )
{
Num_a = rand()%Maxl;
Num_b = rand()%Maxl;
}
else
{
printf("输入有误!");
}
}
  • 数据筛选,剔除重复算式:
 int Data_Filtering(int flag )
{
int j,f3_flag,equ[Maxsize][]; f3_flag = ;
equ[i][]=Num_a;
equ[i][]=flag;
equ[i][]=Num_b;
for(j=i-;j>=;j--)
{
if(equ[i][] == equ[j][])
{
if(equ[i][] == equ[j][])
{
if(equ[i][] == equ[j][])
{
i--;
f3_flag = ;
}
}
}
}
i++;
return f3_flag ;
}
  • 控制是两则运算(+  -)还是四则运算(+  -  *  /):
 int Ctrl_2or4(int b)
{ int f2_c;
if(b == )
{
f2_c = rand()%;
}
else if(b == )
{
f2_c = rand()%;
}
else
{
printf("输入有误!");
}
return f2_c;
}

  6.总结(如何实现程序“模块化”原则):

  利用函数,分层次分模块进行代码编写,将每个功能用函数描述出来,而不是全部都写在主函数里。

  7.PSP:

PSP2.1

任务内容

计划共完成需要的时间(min)

实际完成需要的时间(min)

Planning

计划

15

20

·       Estimate

·  估计这个任务需要多少时间,并规划大致工作步骤

15

20

Development

开发

410

520

··       Analysis

需求分析 (包括学习新技术)

10

20

·       Design Spec

·  生成设计文档

0

0

·       Design Review

·  设计复审 (和同事审核设计文档)

0

0

·       Coding Standard

代码规范 (为目前的开发制定合适的规范)

5

5

·       Design

具体设计

15

20

·       Coding

具体编码

360

450

·       Code Review

·  代码复审

10

10

·       Test

·  测试(自我测试,修改代码,提交修改)

10

15

Reporting

报告

30

45

··       Test Report

·  测试报告

20

25

·       Size Measurement

计算工作量

0

0

·       Postmortem & Process Improvement Plan

·  事后总结 ,并提出过程改进计划

10

20

 

20194651—自动生成四则运算题第一版报告chris的更多相关文章

  1. 自动生成四则运算题目(C语言)

    Github项目地址:https://github.com/huihuigo/expgenerator 合作者:马文辉(3118005015).卢力衔(3118005013) 项目简介 1题目:实现一 ...

  2. 结对项目 实现自动生成四则运算题目的程序 (C++)

    本次作业由 陈余 与 郭奕材 结对完成 零.github地址: https://github.com/King-Authur/-Automatically-generate-four-arithmet ...

  3. java实现自动生成四则运算

    Github项目链接:https://github.com/shoulder01/Fouroperation.git 一.项目相关要求 1. 使用 -n 参数控制生成题目的个数(实现) 2.使用 -r ...

  4. C语言#自动生成四则运算的编程

    #include <iostream> #include <stdio.h> #include <stdlib.h> #include <time.h> ...

  5. C语言编程—自动生成四则运算升级版

    #include<stdio.h> #include<time.h> struct fenshu { int fenzi; int fenmu; }Fenshu[]; int ...

  6. 用C语言编程自动生成四则运算

    #include<stdio.h>#include<stdlib.h>#include <time.h>#define N 30main(){ int a,b,k, ...

  7. 作业二:个人编程项目——编写一个能自动生成小学四则运算题目的程序

    1. 编写一个能自动生成小学四则运算题目的程序.(10分)   基本要求: 除了整数以外,还能支持真分数的四则运算. 对实现的功能进行描述,并且对实现结果要求截图.   本题发一篇随笔,内容包括: 题 ...

  8. 把时间还给洞察,且看PPT调研报告自动生成攻略

    文/JSong @2017.02.28 在数据分析里面有一句话是说,80%的时间要用于数据清洗和整理,而我觉得理想的状态应该是把更多的把时间花在数据背后的洞察当中.去年11月在简书占了个坑,说要自己写 ...

  9. (幼儿园毕业)Javascript小学级随机生成四则运算

    软件工程第二次结对作业四则运算自动生成器网页版 一.题目要求 本次作业要求两个人合作完成,驾驶员和导航员角色自定,鼓励大家在工作期间角色随时互换,这里会布置两个题目,请各组成员根据自己的爱好任选一题. ...

随机推荐

  1. linux防火墙之iptables

    linux防火墙之iptables 1.1.1 关于iptables简介 IPTABLES 是与最新的 3.5 版本 Linux 内核集成的 IP 信息包过滤系统.如果 Linux 系统连接到因特网或 ...

  2. JUnit 5和Selenium基础(一)

    Gradle.JUnit 5和Jupiter Selenium Selenium是一组支持浏览器自动化的工具,主要用于Web应用程序测试.Selenium的组件之一是Selenium WebDrive ...

  3. 小程序中组件公用属性和data-的使用

    属性名                类型                   描述                              注解 hidden                Boo ...

  4. P1551 亲戚 并查集

    P1551 亲戚 题目背景 若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系. 题目描述 规定:x和y是亲戚,y和z是亲戚,那么 ...

  5. 从Main读取appsetting

    using System; using System.Configuration; using Newtonsoft.Json.Linq; using System.Net.Http; using S ...

  6. github 关掉邮件通知

  7. 深入理解es6中的Promise

    https://www.jianshu.com/p/9e4af5b77253 https://zhuanlan.zhihu.com/p/30797777 https://segmentfault.co ...

  8. pycharm 连接mysql失败

    1.下载与之对应的驱动 2.更改数据库的时区(问题大多数出现在这里) .查看时区 show variables like '%time_zone%'; .设置时区 set global time_zo ...

  9. Dijkstra求解单源最短路径

    Dijkstra(迪杰斯特拉)单源最短路径算法 Dijkstra思想 Dijkstra是一种求单源最短路径的算法. Dijkstra仅仅适用于非负权图,但是时间复杂度十分优秀. Dijkstra算法主 ...

  10. 「 从0到1学习微服务SpringCloud 」01 一起来学呀!

    有想学微服务的小伙伴没?一起来从0开始学习微服务SpringCloud,我会把学习成果总结下来,供大家参考学习,有兴趣可以一起来学!如有错误,望指正! Spring .SpringBoot.Sprin ...