c언어 괴짜수 찾는 프로그램
차오름
질문 제목 : 괴짜수 찾는프로그램을 만드는게 과제입니다. 도와주세요.
괴짜수란?
: 입력된 수의 약수들 중 합으로 입력된 수를 만들 수 없는 수
프로그램
1. 숫자 하나를 입력받는다.
2. 입력된 숫자의 약수를 배열에 저장한다.
3. 저장된 약수를 조합하여 괴짜수를 구분한다.
출력
1. 입력된 숫자의 약수를 출력
2. 괴짜수 구분 결과 출력
3. 입력된 수가 괴짜수가 아닐 경우 근거 출력
ex)
숫자를 입력하시오: 12
입력된 숫자 12는 괴짜수가 아닙니다.
근거: 6 + 4 + 2 = 12
(괴짜 수 : 과잉수 중에서 유사완전수가 아닌 수
[참고] 과잉수 : 자기 자신을 제외한 약수를 모두 더한 값이 자신보다 큰 수
유사완전수 : 인수 가운데 일부를 더한 값이 그 수 자신과 같은 수
[예] 수를 찾아서 계산해 보면 되는데 70이 가장 작은 괴짜 수입니다.
70의 인수 : 1,2,5,7,10,14,35,70
70보다 작은 약수를 모두 더하면 1+2+5+7+10+14+35=74
따라서 70은 과잉수
그러나 인수 중에서 일부를 골라 그 합니 70이 되는 경우는 없어서 유사완전수가 아닙니다.
또, 과짜 수는 무수히 많다고 합니다.
하지만 10^6 (10의 6승) 이내에는 24개만 있다고 합니다.
과짜수를 몇 개 더 나열해 보면
70, 836, 4030, 5830, 7192, 7912, 9272,10430,10570,.......)
이게 과제인데요, 여기서 조건을 하나 더추가시켰습니다.
보통 괴짜수의 정의에서는입력한 수를제외한약수의 합을 구했을 경우
그 합이 입력한 수보다 커야되는데,
2, 3, 5, 7 같은 소수나 15와같이 약수가 1, 3, 5, 15이런 식으로 나오는 경우에
입력한 수를제외한 약수들을 더했을 때
그 값이입력한값보다 작은 경우 또한 괴짜수로 놓는다는 조건을 달았습니다.
질문 내용 :일단은 제가미숙한 실력으로 소스를 짜봤는데,
입력된 수를 제외한약수의 합이 입력된 수보다클 경우에
괴짜수와 유사완전수를 판별해 내는 소스가 틀렸는지 적용이 되질않네요.
조언좀 부탁드립니다.
#include stdio.h
void main()
{
int num, i;
int x=0;
int a[1000];
int sum=0;
printf(숫자 하나를 입력해주세요: );
scanf(%d,&num);
for(i=1; inum ;++i) //입력된 수에서 자신을 제외한 약수를 배열에 저장하고 약수들의 합(sum)을 구하기
{
if(num%i==0)
{
a[x]=i;
x++;
printf(%d\n, i);
sum+=i;
}
}
if(sumnum) //약수의 합이 입력된 수보다 작으면 무조건 괴짜수임을 출력
{
printf(%d는(은) 괴짜수이다.,num);
}
if(sumnum) //약수의 합이 입력된 수보다 클 경우 유사완전수와 괴짜수로 구분
{
printf(%d\n,sum);
sum=0;
for(x;x=0;x--)
{
sum+=a[x];
while(sum=num)
{
sum=sum-a[x];
sum=sum+a[x-1];
x--;
if(x=0)
break;}
if(sum=num)
{
printf(유사완전수);
}
else if(sumnum&&sum!=num)
{
printf(괴짜수);
}
break;
}
} //제가 문제가 있다고 생각하는 부분
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |
2691483 | 파일 오픈시 에러 질문드립니다. (2) | 호습다 | 2025-04-14 |
2691450 | [visual c++ 툴]기초 질문 (3) | 해긴 | 2025-04-13 |