1、请编写一个程序分别求解以下问题(请注意保持原有代码的缩进格式):
(1)随机生成100以内的10个整数。
(2)随机选取0到100间的10个奇数。
(3)从字符串'abcdefghij'中随机选取5个字符。
(4)随机输出列表['Apple', ‘Pear’, 'Peach', 'Orange']中的1个字符串。
from random import*
for i in range(10):
print(randint(0,101),end=" ")
print("\n")
for i in range(10):
print(randrange(1,100,2),end=" ")
print("\n")
for i in range(5):
print(choice('abcdefghij'),end=" ")
print("\n")
print(choice(['Apple','Pear','Peach','Orange']),end=" ")
运行效果图
2、(百鸡百钱问题)编程实现:我国古代数学书《张邱建算经》中有一个著名的“百鸡百钱”问题。大意是:公鸡1只值钱5,母鸡1只值钱3,小鸡3只值钱1。今有钱100,买鸡100只。问公鸡、母鸡、小鸡各买几只? 要求每种组合中公鸡、母鸡和小鸡数量均不能为0,试编程求解所有可能的组合。
这道题目有多种代码的写法,这里就只写出一种写法以供查看,思路大体上是差不了多少的。
for gj in range(1,20):
for mj in range(1,33):
if gj*5+mj*3+(100-gj-mj)/3==100:
print("公鸡{}只,母鸡{}只,小鸡{}只".format(gj,mj,100-gj-mj))
3、编程实现:输出 2-1000 以内所有的完数及其因子。所谓完数是指一个数恰好等于它 的各因子之和(如6的因子为1、2、3)。 输出示例:
2-1000以内所有的完数:
6=1+2+3
………
for i in range(2,1001):
n=0
s=''
for j in range(1,i):
if i%j==0:
s=s+str(i)+"+"
n=n+j
if n==i:
print("{}".format(n)+"="+s[:-1])
思路:先从2到1000开始循环,在里面找每个数字的因子,每个因子以字符串的形式串联,再把这些数相加,如果因子的和和数字值相等,那么就将刚才存有因子的字符串切片输出想要的形式。