第七届 蓝桥杯 5题
对这道题的理解
#include <stdio.h>
#define N 6
#define M 5
#define BUF 1024
void f(int a[], int k, int m, char b[])//m是还剩下派的人
{
int i,j;
if(k==N){
b[M] = 0;
if(m==0) printf("%s\n",b);
return;
}
for(i=0;i<=a[k];i++){
for(j=0;j<i;j++) b[M-m+j]=k+'A';//M-m是已经派的人 然后是派A,B...的人去
f(a,k+1,m-i,b);
}
}
int main()
{
int a[N] = {4,2,2,1,1,3};
char b[BUF];
f(a,0,M,b);
return 0;
}