Contents

Develop
2016.09.09 11:16

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

조회 수 2252 댓글 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
번호 분류 제목 글쓴이 날짜 조회 수
1101 Develop 레고 NXT 마인드스톰 밸런싱 로봇 ㅎㅎ file hooni 2013.04.23 57710
1100 Algorithm 러시아 페인트공 알고리즘에 대해.. hooni 2013.04.23 22893
1099 Develop 라이브러리에 대한 설명 (static & dynamic library) hooni 2013.04.23 6942
1098 System/OS 라우팅 경로 결정 영향 요소 ㅋㅋ file hooni 2013.04.23 15848
1097 Algorithm 디피헬만(Diffie-Hellman) 초간단 개념.. hooni 2013.04.23 81017
1096 Develop 도메인 관련 솔루션 분석할 거.. ㅋㄷ file hooni 2013.04.23 6981
1095 Develop 다운 받아서 테스트 해볼것.. hooni 2013.04.23 9131
1094 Develop 다양한 방법으로 아주 큰 수(Big Number) 계산.. ㅋㅋ hooni 2013.04.23 8364
1093 Develop 논문에 들어갈 툴바 테스트 해볼 것.. secret hooni 2013.04.23 8013
1092 Etc 논문(BHO)에 들어갈 내용 집에가서 테스트 해볼 것.. secret hooni 2013.05.28 10230
1091 Develop 논문 실험용 고려대 툴바 ㅎㅎ secret hooni 2013.04.23 8686
1090 System/OS 네트워크별 MTU(최대 전송 단위) hooni 2013.04.23 17639
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 11 ... 98 Next
/ 98