例如,有一个 4x4 整数数组,我需要从每一行中选择一个数字,以便每个所选数字位于不同的列中,并且所选数字的总和尽可能低。有问题的网格如下所示:
1 2 3 1
2 3 1 3
2 2 1 2
3 4 1 9
我的程序返回这个答案:
1* 2 3 1
2 3* 1 3
2 2 1* 2
3 4 1 9*
但最好的解决方案是:
1 2 3 1*
2 3 1* 3
2* 2 1 2
3 1* 1 9
我的功能需要改变什么?
struct r{
bool moze;
int quantity;
};
int ff,m1;
bool check(int n,r **tab, int k)
{
for(int i=0;i<n;i++){
if(tab[k][i].moze==true || tab[i][ff].moze==true)
return false;
}
return true;
}
bool back(int n, r ** tab, int k){
for(int i=0;i<n;i++){
if (check(n,tab,k)){
tab[k][i].moze=true;
if (k==n-1)
{
for(int j=0;j<n;j++)
{
for(int c=0;c<n;c++)
{
if(tab[j][k].moze==true)
cout<<tab[j][i].quantity;
}
}
return true;
}
if (back(n,tab,k+1))
return true;
else
tab[k][i].moze=false;
}
}
return false;
}
如何修复我的功能?
function mark(r, c, available):
for each element in [r][]:
mark available
for each element in [][c]:
mark available
function backtrack(table, temp, r, c, sum):
check if sum is solution
for row i in table:
if temp[i][0] is not available go to next row
for column j in table:
if temp[i][j] is available:
mark(i, j, not available)
backtrack(table, temp, i, j, sum+table[i][j])
mark(i, j, available again)
我有一个伪代码,但我不能把它放在我的函数中,有人可以帮助我,不能帮助自己