小白的自我救赎:Codewars+今日练习

练习1:输入一个正整数判断是不是素数。
提示:素数指的是只能被1和自身整除的大于1的整数。

分析:只需要看这个数除以2~它本身前的一个数的余数会不会为0,一旦为0说明它不是素数,否则是素数

x = int(input('请输入一个正整数:))
for i in range(2,x):
	if x % i == 0:
		print('这个数不是素数')
		break
print('这个数是素数')		

上面的代码我们可以发现,如果一个数是素数,会输出 这个数是素数 但是如果这个数不是素数 就会输出 这个数不是素数 这个数是素数 因此 我们要给最下面的print增加一个输出条件
代码就变成:

x = int(input('请输入一个正整数:))
is_prime = 1
for i in range(2,x):
 if x % i == 0:
  print('这个数不是素数')
  is_prime = 0
  break
while is_prime :
	print('这个数是素数')
	break

练习2:打印如下所示的三角形图案。

*
**
***
****
*****

    *
   **
  ***
 ****
*****

    *
   ***
  *****
 *******
*********

分析:这里面涉及到两个问题,每行有几个*,以及每行有几个空格。

row = int(input('请输入行数:'))
for i in range(row):
	for _ in range(i+1):
		print('*',end='')
	print()

for i in range(row):
	for _ in range(row-i-1):
		print(' ',end='')
	for _ in range(i+1):
		print('*',end='')
	print()

for i in range(row):
	for _ in range(row-i-1):
		print(' ',end='')
	for _ in range(2 * i + 1):
		print("*",end='')
	print()

已经确定了有i个行,再看空格数、*数与i的关系来写
此外,print(’ ‘,end=’’)后面的end=’'的意思是不换行,因为到了下一个print系统默认是换行输出的

练习3:寻找水仙花数。
说明:水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯特朗数,它是一个3位数,该数字每个位上数字的立方之和正好等于它本身,例如: 1 3 + 5 3 + 3 3 = 153 1^3 + 5^3+ 3^3=153 13+53+33=153

分析:这个题是入门python和C的常见题,比较简单

for x in range(100,1000):
    high = x // 100
    mid = x // 10 % 10
    low = x % 10
    if high**3 + mid**3 + low**3 == x:
        print(x)

练习4:百钱百鸡问题。
说明:百钱百鸡是我国古代数学家张丘建在《算经》一书中提出的数学问题:鸡翁一值钱五,鸡母一值钱三,鸡雏三值钱一。百钱买百鸡,问鸡翁、鸡母、鸡雏各几何?翻译成现代文是:公鸡5元一只,母鸡3元一只,小鸡1元三只,用100块钱买一百只鸡,问公鸡、母鸡、小鸡各有多少只?

分析:公鸡最多买20只,母鸡最多买33只

for x in range(21):
	for y in range(34):
		z = 100 - x - y
		if 5 * x + 3 * y + z /3 == 100:
			print('公鸡买了:',x,'只')
			print('母鸡买了:',y,'只')
			print('小鸡买了:',z,'只')
			

练习5:CRAPS赌博游戏。
说明:CRAPS又称花旗骰,是美国拉斯维加斯非常受欢迎的一种的桌上赌博游戏。该游戏使用两粒骰子,玩家通过摇两粒骰子获得点数进行游戏。简单的规则是:玩家第一次摇骰子如果摇出了7点或11点,玩家胜;玩家第一次如果摇出2点、3点或12点,庄家胜;其他点数玩家继续摇骰子,如果玩家摇出了7点,庄家胜;如果玩家摇出了第一次摇的点数,玩家胜;其他点数,玩家继续要骰子,直到分出胜负。

分析:按部就班按流程写代码

from random import randint
go_on = 0
first = randint(1,6) + randint(1,6)
if first == 7 or first == 11:
	print('玩家胜利')
elif first == 2 or first == 3 or first == 12:
	print('庄家胜利')
else:
	go_on = 1
while go_on:
	again = randint(1,6) + randint(1,6)
	if again == 7:
		print('庄家胜利')
		go_on = 0
	elif again == first:
		print('玩家胜利')
		go_on = 0
	else:
		go_on = 1

练习6:生成斐波那契数列的前20个数。
说明:斐波那契数列(Fibonacci sequence),又称黄金分割数列,是意大利数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)在《计算之书》中提出一个在理想假设条件下兔子成长率的问题而引入的数列,所以这个数列也被戏称为"兔子数列"。斐波那契数列的特点是数列的前两个数都是1,从第三个数开始,每个数都是它前面两个数的和,形如:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, …。

我的方法:

output=[1,1]
for i in range(18):
    temp=output[i]+output[i+1]
    output.append(temp)
print(output)

答案:

a = 0
b = 1
for _ in range(20):
    a, b = b, a + b
    print(a, end=' ')

练习7:输出100以内所有的素数。
说明:素数指的是只能被1和自身整除的正整数(不包括1)。

for x in range(2,100):
	is_Prime=1
	for i in range(2,x):
		if x % i ==0:
			is_Prime = 0
			break
	if is_Prime:
		print(x,end=' ')

练习8:找出10000以内的完美数。
说明:完美数又称为完全数或完备数,它的所有的真因子(即除了自身以外的因子)的和(即因子函数)恰好等于它本身。例如:6( 6 = 1 + 2 + 3 6=1+2+3 6=1+2+3)和28( 28 = 1 + 2 + 4 + 7 + 14 28=1+2+4+7+14 28=1+2+4+7+14)就是完美数。

for x in range(1,10000):
	temp = 0
	for i in range(1,x):
		if x % i == 0:
			temp+=i
	if temp == x:
		print(x,' ')

以上是今日循环部分的练习题

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值