zoukankan      html  css  js  c++  java
  • 个人项目一改进

      项目一有一个缺陷就是每次执行程序所产生的随机数都是一样的,这次改进就是使程序每次运行都出现不一样的结果。

      目的:随机产生30个四则运算表达式,要求每次运行的结果都不同。

    //2016/3/9
    
    #include <iostream>
    #include <cmath>
    #include <time.h>
    using namespace std;
    
    //main函数
    void main()
    {
        srand( (unsigned)time( NULL ) );//srand()函数产生一个以当前时间开始的随机种子.应该放在for等循环语句前面 不然要很长时间等待
        int ran1,ran2,oper;
        for(int i=0;i<30;i++)
        {
            
            ran1=rand()%100;//产生第一个随机数
            ran2=rand()%100;//产生第二个随机数
            oper=rand()%4;//oper用来决定进行什么四则运算
            switch(oper)
            {
            case 0:
                cout<<ran1<<"+"<<ran2<<"="<<endl;//进行加运算
                break;
            case 1:
                cout<<ran1<<"*"<<ran2<<"="<<endl;//进行乘运算
                break;
            case 2:
                if(ran1<ran2)
                {
                    int x=ran1;
                    ran1=ran2;
                    ran2=x;
                }//判断被减数是否大于减数,如果不大于,则将两者交换位置,目的是避免出现负数
                cout<<ran1<<"-"<<ran2<<"="<<endl;
                break;
            case 3:
                if(ran2==0)
                    ran2=rand()%100;//判断除数是否为0,如果是,则重新生成
                else 
                    cout<<ran1<<"/"<<ran2<<"="<<endl;//进行除运算
            }
        }
    }

      在for循环前添加一个时间种子,以保证每次运行结果的不同,不能放在for循环里边,经过实验,放在for循环里边会出现30个相同的式子。

  • 相关阅读:
    bzoj 1098 [POI2007] 办公楼 biu
    「 Luogu P2574 」 XOR的艺术——线段树
    「 Luogu P2801 」 教主的魔法——分块
    Luogu P1438 无聊的数列
    「 Luogu P2420 」 让我们异或吧
    「 SPOJ GSS3 」 Can you answer these queries III
    「 HDOJ P2227 」 Find the nondecreasing subsequences
    「 HDOJ P3887 」 Counting Offspring
    一些性质及公式
    OI杂记
  • 原文地址:https://www.cnblogs.com/quite-love/p/5259486.html
Copyright © 2011-2022 走看看