找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 1682|回复: 2

回溯法解决转载问题

[复制链接]
发表于 2009-11-3 03:20:07 | 显示全部楼层 |阅读模式 IP:江苏扬州
#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呢
发表于 2009-11-3 03:20:08 | 显示全部楼层 IP:江苏扬州
程序代码:
#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;
}
回复

使用道具 举报

发表于 2009-11-3 03:20:09 | 显示全部楼层 IP:江苏扬州
就是把i赋值为0吗
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-30 13:15 , Processed in 0.278974 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表