Python 을 사용 하여 수선화 문 제 를 풀다.
2439 단어 python
해결 방법:
방법 1:목록 유도 식 사용
1 data=[i for i in range(100,1000)if pow(i//100,3)+pow(i//10%10,3)+pow(i%10,3)==i]
이 방법 은 비교적 간단 하지만 숫자 는 100-999 에 불과 하 다.이 범 위 를 넘 으 면 1000 을 제외 해 야 하기 때문에 방법 2 에서 나 는 분해 방법 을 사용 하여 한 숫자 를 한 자리,10 자리,백 자리,천 자리,만 자리 등 으로 분해 하기 로 결정 했다.그러면 큰 숫자 를 구 할 수 있 고 코드 도 비교적 간결 하 다.
방법 2:함수 와 순환 사용
1 def d():
2 def f(n):
3 c=list(n[::])
4 return c
5 for i in range(100,100000):
6 d=f(str(i))
7 s=0
8 for j in d:
9 s+=pow(int(j),3)
10 if(s==int(i)):
11 print("%d"%s)
12 d()
프로그램 실행 결과:
153370371407
주해:문 제 를 풀 고 보 니 수선화 수가 이 네 개 밖 에 없 었 는데 문 제 를 해결 할 때 우 리 는 사전에 몰 랐 기 때문에 저 는 개인 적 으로 여러분 들 이 방법 2 를 선택 하 는 것 을 추천 합 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.