”二柱子“个人项目

”二柱子“个人项目

关于二柱子的个人项目,据说……是这么发生的……

二柱子因为懒(,,• ₃ •,,),要给他上小学的儿子编写个能够出小学四则运算题目的程序。老师上课的时候又添加了条件:

1、打印至少30道题

2、除了整数之外,还要支持真分数的四则运算。


      老师上课的时候教导我们,写代码的时候不能拿起来就写,因为我们不能做到一气呵成的连贯式思维,要先列出程序的逻辑思路,而且语言不要过于“官方”,自己能看懂就行,越通俗越好。因此我的简单思路如下:

1、定义两个整型操作数
2、生成两个1-100随机数,并赋值给两个操作数
3、循环输出加减乘除四个运算符
    用1234代替加减乘除四则运算,生成随机数代表随机的运算符(除4求余,case语句)
4、输出
5、真分数:分子比分母小的分数,以分数的形式显示出来
6、30次循环

其中涉及到“C++中生成随机数”这个知识点,我忘记了,就百度了一下,参考了CSDN个人博客上面的代码。如下:

C/C++怎样产生随机数:这里要用到的是rand()函数, srand()函数,C语言/C++里没有自带的random(int number)函数。
(1)  如果你只要产生随机数而不需要设定范围的话,你只要用rand()就可以了:rand()会返回一随机数值, 范围在0至RAND_MAX 间。RAND_MAX定义在stdlib.h, 其值为2147483647。

(2)  如果你要随机生成一个在一定范围的数,你可以在宏定义中定义一个random(int number)函数,然后在main()里面直接调用random()函数。

(3)但是上面两个例子所生成的随机数都只能是一次性的,如果你第二次运行的时候输出结果仍和第一次一样。这与srand()函数有关。srand()用来设置rand()产生随机数时的随机数种子。在调用rand()函数产生随机数前,必须先利用srand()设好随机数种子(seed), 如果未设随机数种子, rand()在调用时会自动设随机数种子为1。上面的两个例子就是因为没有设置随机数种子,每次随机数种子都自动设成相同值1 ,进而导致rand()所产生的随机数值都一样。

srand()函数定义 : void srand (unsigned int seed); 
通常可以利用geypid()或time(0)的返回值来当做seed;

我的个人项目代码如下:(仅供参考,功能不全,写的还有点啰嗦)

  1 //Zhao Ziyin,20160303,Four arithmetics
  2 
  3 #include<iostream>
  4 #include<time.h>
  5 #include<string>
  6 using namespace std;
  7 #define N 30
  8 #define random(x) (rand()%x)
  9 
 10 void main()
 11 {
 12     //循环打印
 13     while (true)
 14     {
 15         cout << "-----------Choose the form of formulas 1 or 2:--------------" << endl;
 16         cout << "              Ⅰ. Integers(like  35 + 64 = )                " << endl;
 17         cout << "              Ⅱ. Proper fraction(like  5/6 × 7/10 = )     " << endl;
 18         int num, i;
 19         int sign_num;//记录运算符号代表的数字
 20         int change;//数值交换的中间值
 21         cin >> num;
 22 
 23         //选择整数运算
 24         if (num == 1)
 25         {
 26             srand((int)time(0));
 27             cout << endl;
 28             cout << "-----There are " << N << " arithmetic problems:-----" << endl;
 29 
 30             //循环打印30次
 31             for (i = 1; i <= N; i++)
 32             {
 33                 int one, two;
 34                 /*srand((int)time(0));*/
 35                 one = rand() % (99 + 1) + 1;
 36                 two = rand() % (99 + 1) + 1;
 37 
 38                 /*srand((int)time(0));*/
 39                 sign_num = (rand() % (99 + 1) + 1) % 4;
 40                 switch (sign_num)
 41                 {
 42                 case(0) :
 43                     cout << i << ".  ";
 44                     cout << one << " + " << two << " = " << endl;
 45                     break;
 46                 case(1) :
 47                     if (one < two)//减法的被减数要大于减数
 48                     {
 49                         change = one;
 50                         one = two;
 51                         two = change;
 52                     }
 53                     cout << i << ".  ";
 54                     cout << one << " - " << two << " = " << endl;
 55                     break;
 56                 case(2) :
 57                     cout << i << ".  ";
 58                     cout << one << " × " << two << " = " << endl;
 59                     break;
 60                 case(3) :
 61                     if (one < two)//除法的被除数要大于除数
 62                     {
 63                         change = one;
 64                         one = two;
 65                         two = change;
 66                     }
 67                     cout << i << ".  ";
 68                     cout << one << " ÷ " << two << " = " << endl;
 69                     break;
 70                 }
 71             }
 72         }
 73 
 74         //选择含有真分数的四则运算
 75         else if (num == 2)
 76         {
 77             string sign;
 78             srand((int)time(0));
 79             cout << endl;
 80             cout << "-----There are " << N << " proper fraction arithmetic problems:-----" << endl;
 81 
 82             for (i = 1; i <= N; i++)
 83             {
 84                 sign_num = (rand() % (99 + 1) + 1) % 4;
 85                 switch (sign_num)//利用随机数随机产生运算符
 86                 {
 87                 case(0) :
 88                     sign = '+'; break;
 89                 case(1) :
 90                     sign = '-'; break;
 91                 case(2) :
 92                     sign = '*'; break;
 93                 case(3) :
 94                     sign = '/'; break;
 95                 }
 96 
 97                 //生成四个随机数分别做两个真分数的分子和分母
 98                 int one, two, three, four;
 99                 /*srand((int)time(0));*/
100                 one = rand() % (99 + 1) + 1;
101                 two = rand() % (99 + 1) + 1;
102                 three = rand() % (99 + 1) + 1;
103                 four = rand() % (99 + 1) + 1;
104                 if (one > two)//第一个真分数的分子要小于分母
105                 {
106                     change = one;
107                     one = two;
108                     two = change;
109                 }
110                 if (three > four)//第二个真分数的分子要小于分母
111                 {
112                     change = three;
113                     three = four;
114                     four = change;
115                 }
116 
117                 int oper_num;
118                 oper_num = (rand() % (99 + 1) + 1) % 3;
119                 switch (oper_num)
120                 {
121                 case(0) ://真分数与真分数运算
122                     cout << i << ".  ";
123                     cout << one << "/" << two << " " << sign << " " << three << "/" << four << " = " << endl;
124                     break;
125                 case(1) ://真分数与整数运算
126                     cout << i << ".  ";
127                     cout << one << "/" << two << " " << sign << " " << four << " = " << endl;
128                     break;
129                 case(2) ://整数与真分数运算
130                     cout << i << ".  ";
131                     cout << one << " " << sign << " " << three << "/" << four << " = " << endl;
132                     break;
133                 }
134             }
135         }
136         //输入的数字错误
137         else
138         {
139             cout << "Choose again!" << endl;
140         }
141 
142     }
143 
144 }

程序的截图如下:

 

最后!!老师说我们每次写代码之前都要估计自己完成任务的时间,然后抓紧时间去完成就会慢慢的提高效率。完成这项任务我用了上课的后20分钟(包括老师的讲解和同学的自我展示交流),还有本周日(20160306)下午三点到四点二十左右的时间。((ㆀ˘・з・˘)我知道自己写代码的速度实在是太慢了,我会以后多多锻炼,提高效率,其实主要是提高自己的智商让自己的逻辑水平更上一层楼。)

      终于完成了人生中第一篇含有代码的博客,虽然累但是还是蛮开森(* ̄ω ̄)真心~

转载于:https://www.cnblogs.com/2016helen/p/5247978.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373539.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

phpstorm9 增加对.vue的支持

1、安装vue.js插件 2、设置javascript version为ECMAScript 6 3、 <script type"text/ecmascript-6"> </script>转载于:https://www.cnblogs.com/lobtao/articles/6044378.html

Eclipse中的集成Git插件删除线上远程分支

Eclipse 的忠实党,在使用Git 多人协作以分支的形式开发应用时分支合并到主干后往往再没什么用(我的做法是保留一两周再干掉),在此记录使用Eclipse的Git 插件来删除无用的分支。 操作步骤: 项目右键 — Team — Remote — Push — Next — Finesh 1,下拉框选择你要删除的远程分支…

mysql 查询系统_使用select和show命令查看mysql数据库系统信息

(1).select显示当前日期和时间mysql> select now();---------------------| now() |---------------------| 2019-06-05 13:46:20 |---------------------1 row in set (0.00 sec)显示当前日期mysql> select curdate();------------| curdate() |------------| 2019-06-0…

从MongoDB GridFS流式传输文件

不久前&#xff0c;我在Twitter上发布了自己的最新作品&#xff0c;即从MongoDB GridFS传输文件进行下载&#xff08;而不是将整个文件存储到内存中然后提供服务&#xff09;&#xff0c;这是我取得的一个小胜利。 我答应就此事写博客&#xff0c;但不幸的是&#xff0c;我的特…

0. 洗好虾和锅 1. 放水放老姜&#xff0c;烧开&#xff0c;放盐 2. 放入虾&#xff0c;沸腾后&#xff0c;尝咸淡 3. 放香葱&#xff0c;乘起来转载于:https://www.cnblogs.com/gary-tao/p/5248139.html

读字库遇到坑爹的问题

转载请注明出处&#xff1a;http://blog.csdn.net/qq_26093511/article/details/53099262 最近在做一个led显示屏的项目&#xff0c; 我想显示 “常”&#xff0c;“州”&#xff0c;“大”&#xff0c;“学”这几个字&#xff0c;但是只能显示 “常” 和 “大”&#xff0c;…

如果–否则为编码风格最佳实践

下面的帖子将是一个高级花括号讨论&#xff0c;没有对与错的答案&#xff0c;只是更多的“品味”。 它是关于是否将“ else”&#xff08;以及其他关键字&#xff0c;例如“ catch”&#xff0c;“ finally”&#xff09;放在换行符上。 有些人可能会写 if (something) {doIt(…

MongoDB 去重(distinct)查询后求总数(count)

在使用MonoDB 做报表汇总经常的有去重统计总数的需求,在此总结一下实现方式: 1, 直接使用distinct 语句查询, 这种查询会将所有查询出来的数据返回给用户, 然后对查询出来的结果集求总数(耗内存,耗时一些) var len db.student.distinct("name",{"age" :…

adobe premiere pro cc2015.0已停止工作 解决办法

adobe premiere pro cc2015.0已停止工作 一直报错 解决办法就是&#xff1a; 删除【我的电脑】- 【我的文档】下的 Adobe 下的Premiere Pro文件夹 现象就是怎么重新安装都不管用Premiere 参考路径 &#xff1a;C:\Users\xxx\Documents\Adobe\Premiere Pro 转载于:https://…

java mysql 语句解析器_几种基于Java的SQL解析工具的比较与调用

1、sqlparserhttp://www.sqlparser.com/优点&#xff1a;支持的数据库最多&#xff0c;除了传统数据库外还支持hive和greenplum一类比较新的数据库&#xff0c;调用比较方便&#xff0c;功能不错缺点&#xff1a;收费&#xff0c;500$起2、Apache Calcite一个构建JDBC或者ODBC访…

Css Sprites 多张图片整合在一张图片上

CSS Sprites原理&#xff1a; CSS Sprites其实就是把网页中一些背景图片整合到一张图片文件中&#xff0c;再利用CSS的“background-image”&#xff0c;“background- repeat”&#xff0c;“background-position”的组合进行背景定位&#xff0c;background-position可以用数…

MongoDB 分析查询性能

cursor.explain(“executionStats”)和 db.collection.explain(“executionStats”) 方法提供关于查询性能的相关信息。这些信息可用于衡量查询是否使用了索引以及如何使用索引。 db.collection.explain() 还提供有关其他操作的执行信息。例如 db.collection.update()。 有关详…

无需复杂插件即可从Eclipse启动和调试Tomcat

像Eclipse这样的现代IDE提供了各种插件来简化Web开发。 但是&#xff0c;我相信将Tomcat作为“常规” Java应用程序启动仍然可以提供最佳的调试体验。 大多数情况下&#xff0c;这是因为这些工具将Tomcat或任何其他servlet容器作为外部进程启动&#xff0c;然后在其上附加一个远…

flutter 国际化_Flutter 开发实战资源推荐

开工第一天&#xff0c;来点轻松的资源推荐。这是一篇实战类资源推荐&#xff0c;其实Flutter的入门资料官方已经做得很好了&#xff0c;如果你是零基础&#xff0c;还是建议先啃一遍官方的教程&#xff0c;然后再看以下实战资源&#xff0c;相信在你看官方课程中涉及到的一些疑…

2-5-666:放苹果

描述把M个同样的苹果放在N个同样的盘子里&#xff0c;允许有的盘子空着不放&#xff0c;问共有多少种不同的分法&#xff1f;&#xff08;用K表示&#xff09;5&#xff0c;1&#xff0c;1和1&#xff0c;5&#xff0c;1 是同一种分法。输入第一行是测试数据的数目t&#xff08…

JSF和“立即”属性–命令组件

JSF中的即时属性通常被误解。 如果您不相信我&#xff0c;请查看Stack Overflow 。 造成这种混乱的部分原因可能是输入&#xff08;即<h&#xff1a;inputText />&#xff09;和命令&#xff08;即<h&#xff1a;commandButton />&#xff09;组件都立即可用&#…

通过joystick遥感和按键控制机器人--11

原创博客&#xff1a;转载请表明出处&#xff1a;http://www.cnblogs.com/zxouxuewei/ 1.首先安装joystick遥控器驱动&#xff1a; sudo apt-get install ros-indigo-joystick-drivers ros-indigo-turtlebot-teleop 2.运行tulterbot机器人&#xff1a; roslaunch rbx1_bringup …

php mysql 线程安全_PHP 线程安全与非线程安全版本的区别深入解析

从2000年10月20日发布的第一个Windows版的PHP3.0.17开始的都是线程安全的版本&#xff0c;这是由于与Linux/Unix系统是采用多进程的工作方式不同的是Windows系统是采用多线程的工作方式。如果在IIS下以CGI方式运行PHP会非常慢&#xff0c;这是由于CGI模式是建立在多进程的基础之…

奶牛健美操(codevs 3279)

题目描述 Description Farmer John为了保持奶牛们的健康&#xff0c;让可怜的奶牛们不停在牧场之间 的小路上奔跑。这些奶牛的路径集合可以被表示成一个点集和一些连接 两个顶点的双向路&#xff0c;使得每对点之间恰好有一条简单路径。简单的说来&#xff0c; 这些点的布局就是…

Nginx 实现网站 http、https 配置

在 nginx conf 目录下新建 ssl 目录&#xff0c;将申请的 ssl证书文件拷贝到此处&#xff1a; 修改 nginx 配置文件使支持 https&#xff0c;修改如下&#xff1a; server {listen 80;listen 443 ssl;ssl_certificate ssl/cert-xuexiyuan.cn.crt;ssl_certificat…