对于每个人所选书号,我们可以采用穷举循环来实现,即从每个人可选书号(1、2、3、4、5)的范围内进行穷举,从而得到可行的结果。对于第一个人的选择,可以用循环将其列出,即for a in range(1,6)。同理,对于第二个人、第三个人可以用同样的方法。由于一本书只能借给一个人,故第二个人的选择会受到第一个人的限制,最后一个人的选择会受到第二个人的限制,即后面的选择都是在前面选择的前提下进行的,所以可采用循环的嵌套来解决问题。
利用循环解决问题的时候,找到循环的三要素,即循环变量的初值、循环的控制条件和使循环趋于结束的循环变量值的改变是进行编程的关键。读者可参照1.4节的例子来找一下本题中所对应的循环三要素。本题的输出结果有一个条件限制:三个人所选书号各不相同。这在输出语句前只要用一个if语句“if a != b and a != c and c != b”进行判断即可。
4.完整的程序
根据上面的分析,编写程序如下:
%%time
# 借书方案知多少if __name__=="__main__":#A、B、C三位小朋友,5本书,每人每次只能借一本#用a、b、c分别表示三人所选图书的编号
i =0# i表示有效借阅次数print("A,B,C三人所选书号分别为:")#用来控制A借阅图书的编号for a inrange(1,6):#用来控制B借阅图书的编号for b inrange(1,6):#用来控制C借阅图书的编号for c inrange(1,6):if a != b and a != c and c != b:print("A:%2d B:%2d C:%2d "%(a, b, c), end='')
i +=1if i %4==0:print()#换行print("共有%d种有效借阅方法"%i)
%%time
# 借书方案知多少if __name__=="__main__":# A、B、C三位小朋友,5本书,每人每次只能借一本# 用a、b、c分别表示三人所选图书的编号
i =0# i表示有效借阅次数print("A,B,C三人所选书号分别为:")
a =1while a <=5:
b =1while b <=5:
c =1while c <=5and a != b:if a != c and b != c:# 控制有效借阅组合print("A:%2d B:%2d C:%2d "%(a, b, c), end='')
i +=1if i %4==0:print()# 换行
c +=1
b +=1
a +=1print("共有%d种有效借阅方法"% i)