24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1098  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 070300化学学硕311分求调剂 +11 梁富贵险中求 2026-04-04 11/550 2026-04-06 10:43 by 蓝云思雨
[考研] 085410人工智能 初试316分 求调剂 +7 残星拂曙 2026-03-31 7/350 2026-04-06 10:09 by 蓝云思雨
[考研] 一志愿河北工业大学材料工程,初试344求专硕调剂 +4 15933906766 2026-04-05 4/200 2026-04-06 07:22 by hmn_wj
[考研] 化学0703-一志愿211-338分求调剂 +8 vants 2026-04-05 8/400 2026-04-06 06:17 by houyaoxu
[考研] 生物与医药求调剂 +5 heguanhua 2026-04-05 6/300 2026-04-05 22:58 by Hdyxbekcb
[考研] 326求调剂 +3 顾若浮生 2026-04-05 3/150 2026-04-05 18:32 by 蓝云思雨
[考研] 271分求调剂学校 +12 zph158488! 2026-04-02 13/650 2026-04-05 10:13 by lqwchd
[考研] 290求调剂 +7 luoziheng 2026-04-04 7/350 2026-04-04 23:17 by lqwchd
[考研] 材料调剂 +18 一样YWY 2026-04-02 19/950 2026-04-04 22:14 by hemengdong
[考研] 315求调剂 +13 小羊小羊_ 2026-04-02 14/700 2026-04-04 20:30 by 蓝云思雨
[考研] 278求调剂 +3 依旧! 2026-04-02 4/200 2026-04-04 20:27 by 蓝云思雨
[考研] 293求调剂 +5 末未mm 2026-04-02 6/300 2026-04-03 15:20 by 王保杰33
[考研] 320求调剂 +5 振—TZ 2026-04-02 5/250 2026-04-03 14:42 by fxue1114
[考研] 求调剂不挑专业 +3 xrh030412 2026-04-01 3/150 2026-04-03 14:40 by 氮气气气
[考研] 调剂 +7 祉岷. 2026-04-02 7/350 2026-04-03 09:11 by 花呗还欠600
[考研] 一志愿北交大材料工程总分358 +8 cs0106 2026-04-01 9/450 2026-04-02 10:36 by 不吃魚的貓
[考研] 【调剂】一志愿厦大生物与医药调剂 +3 Echo虾米 2026-03-31 3/150 2026-04-01 08:40 by JourneyLucky
[考研] 合肥区域性重点一本招收调剂 +4 6266jl 2026-03-30 8/400 2026-03-31 18:43 by 6266jl
[考研] 080500-315分复试调剂 +9 上岸3821 2026-03-31 9/450 2026-03-31 17:29 by 唐沐儿
[考研] 考研调剂求助 +7 13287130938 2026-03-31 7/350 2026-03-31 16:39 by 690616278
信息提示
请填处理意见