Contents

Develop
2016.09.09 11:16

[c] 셀프 넘버(Self Number) 구하기

조회 수 2256 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

어떤 자연수 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;
}



?
  • ?
    baybetube 2018.04.19 17:07
    이야 기막힌 풀이네요. 잘 보고 갑니다.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
841 Develop 프로그램 문서 관리 (Doxygen) hooni 2013.04.23 16385
840 Develop 프로그래밍에서 foo, bar 함수의 유래 file hooni 2013.06.25 21247
839 Develop 프로그래밍 소스 관련 사이트.. hooni 2013.04.23 16485
838 Develop 페이팔에서 돈 찾기 (Paypal withdraw) file hooni 2014.02.20 11372
837 Develop 캘리포니아 운전면허 족보 file hooni 2017.06.12 732
836 Develop 최근 논문 자료 (2011/01/03, 만현형한테 보낸거..) secret hooni 2013.04.23 10366
835 Develop 참고하고 지울 자료.. 집에서 바야지.. ㅋㅋ file hooni 2013.04.23 12121
834 Develop 정리할 자료. file hooni 2015.07.02 677
833 Develop 자주 쓰는 Docker 명령어 alias hooni 2020.01.10 269203
832 Develop 이어서 작업할 내용~ secret hooni 2013.11.21 0
831 Develop 웹페이지 성능 테스트 툴 설명 hooni 2013.04.23 27443
830 Develop 알고리즘 성능분석 file hooni 2014.06.24 2959
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 71 Next
/ 71