24小时热门版块排行榜    

查看: 1081  |  回复: 6

匿名

用户注销 (正式写手)

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

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的回帖

chentianyu1

木虫 (小有名气)

应该是flags [ i ]
晕了,不加空格就显示不出来
5楼2011-10-03 17:19:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

匿名

用户注销 (正式写手)

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

thar-sfc

新虫 (初入文坛)

谢谢,也学习一次
7楼2013-06-04 18:50:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 waveact 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 环境工程调剂 +6 大可digkids 2026-03-16 6/300 2026-03-16 17:16 by barlinike
[考研] 0703化学336分求调剂 +3 zbzihdhd 2026-03-15 3/150 2026-03-16 16:44 by 我的船我的海
[考研] 0703化学调剂 +6 妮妮ninicgb 2026-03-15 9/450 2026-03-16 16:40 by houyaoxu
[考研] 中科院材料273求调剂 +4 yzydy 2026-03-15 4/200 2026-03-16 15:59 by Gaodh_82
[考研] 070303一志愿西北大学学硕310找调剂 +5 d如愿上岸 2026-03-12 8/400 2026-03-16 15:19 by peike
[考研] 材料与化工一志愿南昌大学327求调剂推荐 +7 Ncdx123456 2026-03-13 8/400 2026-03-16 12:15 by karry wen
[基金申请] NSFC申报书里申请人简历中代表性论著还需要在申报书最后的附件里面再上传一遍吗 20+5 NSFC2026我来了 2026-03-10 14/700 2026-03-15 23:53 by 不负韶华的虎
[考研] 26考研一志愿中国石油大学(华东)305分求调剂 +3 嘉年新程 2026-03-15 3/150 2026-03-15 13:58 by 哈哈哈哈嘿嘿嘿
[考研] 294求调剂 +3 Zys010410@ 2026-03-13 4/200 2026-03-15 10:59 by zhq0425
[考研] 297求调剂 +4 学海漂泊 2026-03-13 4/200 2026-03-14 11:51 by 热情沙漠
[考研] 一志愿安徽大学材料工程专硕313分,求调剂的学校 +8 Yu先生 2026-03-10 10/500 2026-03-14 01:04 by JourneyLucky
[考研] 材料与化工求调剂一志愿 985 总分 295 +8 dream…… 2026-03-12 8/400 2026-03-13 22:17 by 星空星月
[考研] 308求调剂 +5 是Lupa啊 2026-03-11 5/250 2026-03-13 22:13 by JourneyLucky
[考研] 26调剂/材料科学与工程/总分295/求收留 +9 2026调剂侠 2026-03-12 9/450 2026-03-13 20:46 by 18595523086
[考研] 301求调剂 +6 Liyouyumairs 2026-03-11 6/300 2026-03-13 20:11 by JourneyLucky
[考研] 0703化学求调剂 +7 绿豆芹菜汤 2026-03-12 7/350 2026-03-13 17:25 by njzyff
[考研] 310求调剂 +3 【上上签】 2026-03-11 3/150 2026-03-13 16:16 by JourneyLucky
[考研] 工科278分求调剂 +5 周慢热啊 2026-03-12 7/350 2026-03-13 15:49 by JourneyLucky
[考研] 283求调剂,材料、化工皆可 +8 苏打水7777 2026-03-11 10/500 2026-03-13 09:06 by Linda Hu
[考博] 26读博 +4 Rui135246 2026-03-12 10/500 2026-03-13 07:15 by gaobiao
信息提示
请填处理意见