c语言回溯法难吗,回溯法解决五人分书问题太难了啊!!谁会啊,太郁闷了!

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

/*分书问题*/

#include

int count=0;

int row=0;

void try(int array[5][5],int row);

void printsolution(int sign[5][5],int count);

int sign[5][5]={{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0}};

main()

{

int array[5][5]={{0,0,1,1,0},{1,1,0,0,1},{0,1,1,0,1},{0,0,0,1,0},{0,1,0,0,1}};

try(array,0);

printf("\n共有%d种分配方案",count);

system("pause");

return 0;

}

void try(int array[5][5],int row)

{int col,i,flag=1;

for(col=0;col<5;col++)

if(array[row][col]==1)

{ if(row>=1)

{for(i=0;i<=row-1&&flag==1;i++)

if(sign[i][col]==1)

flag=0;

}

if(flag==1)

{sign[row][col]=1;

if(row==4)

{count++;

printsolution(sign,count);

}

else

{

row++;

try(array,row);

}

}

}

}

void printsolution(int sign[5][5],int count)

{int i,j;

char people[6]={'A','B','C','D','E','\0'};

printf("第%d个解决方案是:\n",count);

for(i=0;i<5;i++)

for(j=0;j<5;j++)

if(sign[i][j]==1)

printf("%d号书分配给%c\n",j,people[i]);

for(i=0;i<5;i++)

for(j=0;j<5;j++)

sign[i][j]=0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值