码迷,mamicode.com
首页 > 其他好文 > 详细

10个操作数的随机四则运算(二)

时间:2016-03-12 10:25:52      阅读:137      评论:0      收藏:0      [点我收藏+]

标签:

上一个版本有一点小问题,插括号时考虑的太少了,丢掉了几种情况,所以导致括号的数量稀少,所以我稍微改进了一下,还有,我按照老师的标准把格式也稍微改了一下

下面是我改进后的代码

#include<iostream>
#include<cstdlib>
#include<set>
#include<ctime>
#include<string.h>
#include<string>
#include<sstream>
using namespace std;
#define random(x) (rand()%x)
int a[100];
char s[4]={+,-,*,/};
char sym[100];
char brackets[100];
int num[100];
string numToString(int num)
{
    stringstream ss;
    string as="";
    ss<<num;
    ss>>as;
    return as;
}
void dfs(int s,int e)//使用dfs递归添加括号 
{
    if(!random(4)) //四分之一的概率,不进行任何操作 
    {
        return;
    }
    if(e-s<=1)//只有一个元素或没有元素,不进行任何操作 
    {
        return;
    } 
    int s1=random(e-s-1)+s;//随机生成插入括号的位置 
    int e1=random(e-s1)+s1;
    while(s1<s||e1>e||s1>=e1||(s1==s&&e1==e))//避免无用括号 
    { 
        s1=random(e-s-1)+s;e1=random(e-s1)+s1;
    }
    if(brackets[s1]==)||brackets[e1]==() 
    {
        return;
    } 
    brackets[s1]=(;
    brackets[e1]=);
    num[s1]++;
    num[e1]++; 
    dfs(s,s1-1);//插入括号的左边几个元素 
    dfs(e1+1,e);//括号之间的几个元素 
    dfs(s1,e1);//括号右边的几个元素 
}
int main()
{
    srand(time(NULL)); 
    int T=30,n;
    set<string> mySet;
    string ans;
    while(T--)
    {
        ans="";
        n=random(8)+2;
        memset(brackets,.,sizeof(brackets));
        memset(num,0,sizeof(num));
        for(int i=1;i<=n;i++)
        {
            a[i] = random(999)+1;
            sym[i]=s[random(4)];
        }
        dfs(1,n);
        while(brackets[1]==(&&num[1]--)
        {
            ans+=(;
        }
        ans+=numToString(a[1]);
        for(int i=2;i<=n;i++)
        {
            ans+=sym[i];
            while(brackets[i]==(&&num[i]--)
            {
                ans+=(;
            } 
            ans+=numToString(a[i]);
            while(brackets[i]==)&&num[i]--)
            {
                ans+=); 
            } 
        }
        if(!mySet.count(ans)){
            cout<<ans<<endl;
            mySet.insert(ans);
        }
        else
        {
            T++;
        }
        
    }
    return 0;
}

 

 

10个操作数的随机四则运算(二)

标签:

原文地址:http://www.cnblogs.com/yifan2016/p/5267958.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!