| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 668 人关注过本帖
标题:回溯法解决转载问题
只看楼主 加入收藏
diaoxue
Rank: 1
等 级:新手上路
帖 子:142
专家分:0
注 册:2007-6-1
收藏
 问题点数:0 回复次数:4 
回溯法解决转载问题
#include <iostream.h>
const int MAX=10;
const int n=3;
const int i=1;
int w[]={10,40,40};
int cw=0,bestw=0,r=90,c=50;
int bestx[MAX],x[MAX];
int Backtrack(int i)
{
    if(i>n)
    {
        if(cw>bestw)//比上次大 更新记录
        {
            for(int j=1;j<=n;j++)
                bestx[j]=x[j];
            bestw=cw;
        }
        return 0;
    }
    r-=w[i];
    if(cw+w[i]<=c)//能装下 搜索左子树
    {
        x[i]=1;
        cw+=w[i];
        Backtrack(i+1);
        cw-=w[i];
    }
    if(cw+r>bestw)//搜索右子树 加上剩下的比现在最优的大,可能是最优解
    {
        x[i]=0;
        Backtrack(i+1);
    }
    r+=w[i];
}
int main()
{
    Backtrack(i);
    cout<<bestw<<endl;
    for(int i=0;i<MAX;i++)
        cout<<bestx[i];
    cout<<endl;
    return 0;
}

编译是有个警告:就是说不是每个执行路径都有返回值,但是加在BackT函数最后后,结果还是一样,应该是50才对啊,怎么是40呢
搜索更多相关主题的帖子: int bestw 回溯 const MAX 
2007-11-25 09:46
leeco
Rank: 4
等 级:贵宾
威 望:10
帖 子:1029
专家分:177
注 册:2007-5-10
收藏
得分:0 
程序代码:
#include <iostream>
using namespace std;

const int MAX=10;
const int n=3;
//const int i=1;
int w[]={10,40,40};
int cw=0,bestw=0,r=90,c=50;
int bestx[MAX],x[MAX];
int Backtrack(int i)
{
        if(i>=n)
        {
                if(cw>bestw)
                {
                        for(int j=0;j<n;j++)
                                bestx[j]=x[j];
                        bestw=cw;
                }
                return 0;
        }
        r-=w[i];
        if(cw+w[i]<=c)
        {
                x[i]=1;
                cw+=w[i];
                Backtrack(i+1);
                cw-=w[i];
        }
        if(cw+r>bestw)
        {
                x[i]=0;
                Backtrack(i+1);
        }
        r+=w[i];
}
int main()
{
        Backtrack(0);
        cout<<bestw<<endl;
        for(int i=0;i<n;i++)
                cout<<bestx[i];
        cout<<endl;
        scanf("%*s");
        return 0;
}
2007-11-25 18:10
diaoxue
Rank: 1
等 级:新手上路
帖 子:142
专家分:0
注 册:2007-6-1
收藏
得分:0 
回复 2# 的帖子
就是把i赋值为0吗

上善若水,水善利万物而不争,处众人之所恶
2007-11-27 15:12
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
收藏
得分:0 
什么是转载问题?

Fight  to win  or  die...
2007-11-27 15:41
diaoxue
Rank: 1
等 级:新手上路
帖 子:142
专家分:0
注 册:2007-6-1
收藏
得分:0 
回复 4# 的帖子
不好意思
是装载问题

上善若水,水善利万物而不争,处众人之所恶
2007-11-27 21:08
快速回复:回溯法解决转载问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018540 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved