완벽한 숫자 프로그램을 쓰다
다음은 프로그램 코드에 다중 스레드를 넣지 않았지만, 현재의 CPU는 이미 매우 빨라서 순식간에 끝났다.
package com.yourcompany.struts;
public class PerfectNumber {
public static void main(String[] args) {
// int sum, k;
int perfectNum[] = new int[100];
for (int num = 1; num <= 10000; num++) {
int sum = 0;
int maxPer = 0;
for (int i = 1; i <= num - 1; i++) {
if (num % i == 0) {
sum = sum + i;
perfectNum[maxPer++] = i;
}
}
if (num == sum) {
System.out.print(num + "=");
for (int i = 0; i < maxPer; i++) {
if (i > 0) {
System.out.print("+");
}
System.out.print(perfectNum[i]);
}
System.out.print("
");
}
}
}
}
실행 결과는 다음과 같습니다.
6=1+2+328=1+2+4+7+14496=1+2+4+8+16+31+62+124+2488128=1+2+4+8+16+32+64+127+254+508+1016+2032+4064
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Java 다중 스레드를 순차적으로 실행하는 몇 가지 방법 요약Java 다중 스레드를 순차적으로 실행하는 몇 가지 방법 요약 동료는 무심결에 이 문제를 제기하고 두 가지 방법을 직접 실천했다.물론 더 좋은 방법이 있을 거야. 방법 1 이런 방법은 비교적 흔히 볼 수 있는 해결 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.