1. 编写程序,计算并输出1- 1/2 + 1/3 - 1/4 + +1/99 - 1/100的值(结果保留4为小数)
n = int(input('numbers'))
x = 1
b = -1
sum = 0
while x <= n:
sum = sum - b / x
x = x + 1
b = -b
print('%.4f' % sum)
2.编写程序,从键盘输入a和n,求a+aa+aaa+.+aa...a(n个a)的值。例如,从键盘输入a的值为2,n的值为5,输出24690。规定: a和n均为正整数,且1<a<9。
a, n = map(int, (input().split()))
b = a
s = 0
i = 1
while i <= n:
s = s + a
a = a * 10 + b
i = i + 1
print(s)
3. 给定一个大于1的自然数,如果它只能被1和它本身整除,那么这个自然数是素数。例如,2是素数,7是素数,9不是素数。编写程序,从键盘输入一个大于1的自然数,判断它是否是素数.
num = int(input("请输入一个数字:"))
if num > 1:
for i in range(2, num):
if (num % i) == 0:
print(num, "不是质数")
print(i, "乘于", num // i, "是", num)
break
else:
print(num, "是质数")
else:
print(num, "不是质数")
4.自幂数是指一个n位数,它的每个数位上的数字的n次幂之和等于它本身。3位数的自幂数称为水仙花数,4位数的自幂数称为玫瑰花数。编写程序,打印所有的玫瑰花数,并计算玫瑰花数的个数。
count = 0
for i in range(1000, 10000):
x = int(str(i)[0]) # 利用str先将int类型转换成字符串
y = int(str(i)[1]) # 然后字符串切片获取 个十百千位上的数字
z = int(str(i)[2]) # 再转换成int 类型 这样 每个变量分别对应每个个十百千位上的数字了
c = int(str(i)[3])
# 用 if语句来判断是否符合玫瑰数
if x ** 4 + y ** 4 + z ** 4 + c ** 4 == i:
print(i)
count+=1
print(f"玫瑰花数为{count}个")