编程题目:小明有5本新书,要借给A,B,C三个小朋友,若每人每次最多只能借1本,则可以有多少种不同的借法?
问题分析:三个小朋友每人借5本书中的一本,从这里就可以看出一定会有循环,且循环为3个,由于两两之间无法借同一本书,所以在循环中必须要有一个判断条件
程序:
#include <stdio.h>
int main()
{
int A;
int B;
int C;
for(A = 1; A <= 5; A++)
{
for(B = 1; B <= 5; B++)
{
for(C = 1; C <= 5; C++)
{
if((A != B) && (A !=C) && (B != C))
{
printf("A:%d, B:%d, C:%d\n",A,B,C);
}
}
}
}
return 0;
}
运行结果
代码优化:
dsjj
在此程序中还可以继续改进,一旦第一二个人选择了同一本书,就没有必要进行第三次循环,并且在第二次循环式可以加上不等于第一次选择的书的条件,第三次循环加上不等于第一、二次选择的书的条件,这样就可以减少运行时间,提高运行效率。