24小时热门版块排行榜    

CyRhmU.jpeg
查看: 966  |  回复: 6
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

匿名

用户注销 (正式写手)

本帖仅楼主可见

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   同方向广播   申请信息EPI   回复此楼   编辑   查看我的主页

匿名

用户注销 (正式写手)

本帖仅楼主可见
6楼2013-05-22 00:19:09
已阅   申请信息EPI   回复此楼   编辑   查看我的主页
查看全部 7 个回答

chentianyu1

木虫 (小有名气)

【答案】应助回帖

waveact(金币+10): n为变量,为1-10000的整数中的某一个。待会好好琢磨一下你的代码,谢谢你的帮助 2011-10-03 15:38:09
N有多大?深度优先搜索知道做吗?用深度优先搜索,就是个递归的思想。
下面是伪代码。

int n=10;
int[] a;  //a数组记录每一个空位放的什么数字
bool[] flags;    //flags记录哪些数字被用过了

void Show_Result()    //输出一组解
{
    输出a数组;
}

void Find_Next_Pair(int k)    //找下一对应该填什么数,k表示当前填到的位置(1..k-1的空位都填满了,现在要填k位和k+1位,k必为奇数)
{
    if (k>=n)   //如果所有n个空位都填满了,则输出这组解,并回到选择n-1和n两个空位的函数上去
   {
       Show_Result();
       Return;
    }
    for (int i=1;i<=n;i++)    //看看1..n这些数哪些在1..k-1位还没用过的,可以在第k位尝试放这些数
       if (!flags)
          for (int j=i+1;j<=n;j++)   //同上,在第k+1位尝试放一个数,因为一个pair里面顺序无关,因此j从i+1开始取
            if (!flags[j])
            {
                  flags=true;
                  flags[j]=true;
                  a[k]=i;
                  a[k+1]=j;
                  Find_Next_Pair(k+2);    //第k位和k+1位都填好了,继续填k+2位
            }
    flags=false;
    flags[j]=false;
}

main()
{
    a=new int[n];
    flags=new bool[n];
    Find_Next_Pair(1);
}
2楼2011-10-02 19:09:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chentianyu1

木虫 (小有名气)

n可能有一万?这个不太现实吧,n最多是两位数吧。你用排列组合算算,如果N到一万,肯定爆了,这个结果数量是指数级的啊。

p.s.上面的程序有问题的
if (!flags)
这一句要改成
if (!flags&& ((k==1)||(i>a[k-1])))
昨天一个是忘写了,再一个没考虑两个pair的顺序造成的重复
3楼2011-10-03 17:17:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chentianyu1

木虫 (小有名气)

论坛有bug啊,昨天不是忘写flags [ i ],而是论坛显示不出来啊。
那个flags里面应该是
4楼2011-10-03 17:19:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见