Develop
2016.09.09 11:16
[c] 셀프 넘버(Self Number) 구하기
Views 2380 Comment 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 •
-
?
이야 기막힌 풀이네요. 잘 보고 갑니다.
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
769 | Develop | [c++] 기초강좌 #01(입출력,영역지정) | hooni | 2003.04.23 | 11464 |
768 | Develop | [c++] 기초강좌 #02(레퍼런스,메모리할당) | hooni | 2003.04.23 | 11476 |
767 | Develop | [c++] 기초강좌 #03(함수의 매개변수 전달) | hooni | 2003.04.23 | 12134 |
766 | Develop | [c++] 기초강좌 #04(클래스) | hooni | 2003.04.23 | 11867 |
765 | Develop | [c] C로 구현한 CGI - 방명록 | hooni | 2003.04.23 | 33507 |
764 | Develop | [c] C로 구현한 CGI - 계산기 (링크리스트, 스택, 이진트리) | hooni | 2003.04.23 | 28151 |
763 | Develop | [c] C로 구현한 CGI - 달력과 날짜계산기 | hooni | 2003.04.23 | 32457 |
762 | Develop | [jsp] 유효성체크(Client, Server 에서) | hooni | 2003.04.23 | 7460 |
761 | Develop | [js] 키보드 아스키 코드 확인하는 간단한 소스 | hooni | 2003.04.23 | 7790 |
760 | Develop | [js] 핫키(단축키) 구현방법 | hooni | 2003.04.23 | 7652 |
759 | Develop | [js] 이미지 미리 로딩하기 | hooni | 2003.04.23 | 7034 |
758 | Develop | [html] 캐쉬된 웹페이지 사용하지 않도록 하는 방법 | hooni | 2003.04.23 | 13066 |