求水仙花数(用不同的方法) 送鱼币了
本帖最后由 Angelina_Jolie 于 2022-1-14 15:45 编辑1. 寻找水仙花数
题目要求:如果一个3位数等于其各位数字的立方和,则称这个数为水仙花数。例如 153 = 1^3+5^3+3^3,因此 153 是一个水仙花数。编写一个程序,找出所有的水仙花数。 我自己先做一遍
def narcissus(x=100):
while x < 1000:
x += 1
if x == int(str(x)) ** 3 + int(str(x)) ** 3 + int(str(x)) ** 3:
print(x)
narcissus() 本帖最后由 傻眼貓咪 于 2022-1-14 20:08 编辑
def narcissistic(n):
for num in range(10**(n-1), 10**n):
sum = 0; temp = num
while temp:
sum += (temp%10)**n
temp //= 10
if sum == num:
print(num)
narcissistic(3)
narcissistic(4)
narcissistic(5)153
370
371
407
1634
8208
9474
54748
92727
93084 {:10_256:} #include <stdio.h>
void narcissus(size_t value) {
if(value >= 1000) return;
size_t a = value / 100 % 10;
size_t b = value / 10 % 10;
size_t c = value % 10;
if(a * a * a + b * b * b + c * c * c == value)
printf("%lu\n", value);
narcissus(value + 1);
}
int main(void) {
narcissus(100);
return 0;
}
阿萨德按时 发表于 2022-1-14 16:03
想骗我鱼币哈哈 {:10_266:}还没学到 {:10_256:} 除了将3位数拆分为3个一位数,还可以反过来用3个一位数来运算。
for i in range(1, 10):
for j in range(10):
for k in range(10):
if i * 100 +j * 10 +k == i ** 3 +j ** 3 +k ** 3:
print(i, j, k ,sep = '')
另外循环中反复计算立方值,可以先计算出0~9的立方,放到一个列表中,减少运算量。 {:5_109:} {:5_109:} {:10_279:} 膜拜大佬 for i in range(100,1000):
a=i//100
b=(i-100*a)//10
c=i-100*a-10*b
if i==a**3+b**3+c**3:
print(i) @鱼C-小师妹 骗个鱼币
{:10_245:}{:10_245:}{:10_245:} #include <stdio.h>
int main()
{
int i, a, b, c;
for (i = 100; i < 10000; i ++)
{
a = i/100;
b = i%100/10;
c = i%10;
if(a * a * a + b * b * b + c * c * c)
{
printf("%d\t", i);
}
}
return 0;
}
骗个币{:10_277:} {:10_254:}