Develop
2016.09.09 11:16
[c] 셀프 넘버(Self Number) 구하기
조회 수 2373 댓글 1
어떤 자연수 n이 있을 때, d(n)을 n의 각 자릿수 숫자들과 n 자신을 더한 숫자라고 정의하자.
예를 들어 d(91) = 9 + 1 + 91 = 101
이 때, n을 d(n)의 제네레이터(generator)라고 한다. 위의 예에서 91은 101의 제네레이터이다.
어떤 숫자들은 하나 이상의 제네레이터를 가지고 있는데, 101의 제네레이터는 91 뿐 아니라 100도 있다.
그런데 반대로, 제네레이터가 없는 숫자들도 있으며, 이런 숫자를 인도의 수학자 Kaprekar가
셀프 넘버(self-number)라 이름 붙였다.
예를 들어 1,3,5,7,9,20,31 은 셀프 넘버 들이다.
1번 문제
1 이상이고 5000 보다 작은 모든 셀프 넘버들의 합을 구하라.
# Self Number.
#include <stdio.h> int main(){ int a, b, c, d, res, sum=0; int p[5000] = {0,}; for(int num=1; num<5000; num++){ //find self number a = num / 1000; b = (num / 100) % 10; c = (num / 10) % 10; d = num % 10; res = a + b + c + d + num; if(res < 5000){ p[res] = 1; } //make sum if(p[num] == 0){ printf("%3d ", num); sum += num; } } printf("\nThe sum is %d\n", sum); return 0; }
TAG •
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
625 | Develop | [c] 간단한 순위 루틴.. (질문에 대한 답변) | hooni | 2003.04.23 | 7493 |
624 | Develop |
[c] 간단한 자료구조(stack, queue, linked list) 구현 소스
6 ![]() |
hooni | 2003.04.23 | 10149 |
623 | Develop | [c] 간단한 점 이동 샘플 소스코드 | hooni | 2013.04.23 | 6575 |
622 | Develop |
[c] 간단한 채팅(클라이언트/서버) 프로그램 소스
![]() |
hooni | 2003.04.23 | 9090 |
621 | Develop |
[c] 거리와 각도를 입력받아서 좌표로 변환
![]() |
hooni | 2013.04.23 | 10830 |
620 | Develop |
[c] 게임 AI FSM 테스트 샘플 소스.. 꽤 괜찮은 소스..
![]() |
hooni | 2013.04.23 | 7394 |
619 | Develop |
[c] 격자 직사각형 넓이 구하기
![]() |
hooni | 2013.04.23 | 7472 |
618 | Develop |
[c] 공용체를 이용해 MSB를 LSB로 변환
![]() |
hooni | 2013.04.23 | 9387 |
617 | Develop | [c] 관계형 연산자에 대한 설명 | hooni | 2013.04.23 | 7677 |
616 | Develop |
[c] 구구단 최단라인 ㅡㅡ;
![]() |
hooni | 2013.04.23 | 8057 |
615 | Develop |
[c] 구조체 배열 예제 (학생 성적 계산)
![]() |
hooni | 2013.04.23 | 7680 |
614 | Develop |
[c] 구조체/파일 입출력 프로그램
![]() |
hooni | 2003.04.23 | 7082 |