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;
}
} //제가 문제가 있다고 생각하는 부분
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |
2675297 | Prity 비트 발생기 | 한란 | 2024-11-16 |