| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 521 人关注过本帖
标题:一道回溯法的题目
只看楼主 加入收藏
飞天小丰
Rank: 2
等 级:论坛游民
帖 子:19
专家分:50
注 册:2010-7-16
结帖率:40%
收藏
已结贴  问题点数:20 回复次数:1 
一道回溯法的题目
设有A,B,C,D,E五人从事J1,J2,J3,J4,J5这五项工作,每人只从事一项,他们的效益如下图所示。每人选择五项工作中的一项,在各选择组合中,找到效益最高的一种组合。
  | J1 J2 J3 J4 J5
——————————
A | 13 11 10  4  7
B | 13 10 10  8  5
C |  5  9  7  7  4
D | 15 12 10 11  5
E | 10 11  8  8  4

各位兄弟们,此题需用回溯法求解,望会的兄弟帮帮忙,小的不胜感激!
搜索更多相关主题的帖子: 回溯 
2010-12-05 15:58
渊奇绝
Rank: 2
来 自:江苏
等 级:论坛游民
威 望:3
帖 子:9
专家分:36
注 册:2010-12-5
收藏
得分:20 
#include<iostream>
using namespace std;

int **array;
int max_s;
bool *state;
int n;

void re(int x,int s)
{
    int i,j;
    if(x==n)
    {
        if(max_s<s)
        {
            max_s=s;
        }
        return;
    }
    for(i=0;i<n;i++)
    {
        if(state[i]==false)
        {
            state[i]=true;
            re(x+1,s+array[x][i]);
            state[i]=false;
        }
    }
}

int main()
{
    freopen("1.txt","r",stdin);
    int i,j;
    scanf("%d",&n);
    array=new int*[n];
    state=new bool[n];
    for(i=0;i<n;i++)
    {
        array[i]=new int[n];
        state[i]=false;
    }
    max_s=0;
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            scanf("%d",&array[i][j]);
        }
    }
    re(0,0);
    printf("%d",max_s);
   
}
2010-12-05 20:44
快速回复:一道回溯法的题目
数据加载中...
 
   



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

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