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
번호 분류 제목 글쓴이 날짜 조회 수
1113 System/OS 무선 인증 서버.. 김도.. ㅋㅋ file hooni 2013.04.23 17593
1112 System/OS 무료로 HTTPS 적용하기 (Lets' Encrypt) file hooni 2017.02.16 2156
1111 System/OS 무료로 HTTPS 적용하기 (Let's Encrypt) file hooni 2017.10.28 1392
1110 Develop 모터에 대한 pid 제어.. ㅎㅎ file hooni 2013.04.23 18873
1109 Etc 모바일 프로그래머가 갖추어야 할 필수 역량 file hooni 2017.02.16 1281
1108 System/OS 맥에서 포트 확인하고 닫기 (mac) hooni 2022.03.22 878
1107 System/OS 맥에서 파일공유 (윈도우,맥) file hooni 2013.04.25 37298
1106 System/OS 맥북에서 MAC/윈도우 멀티부팅시 시간 설정 file hooni 2013.04.23 29757
1105 System/OS 맥 OS X 에서 스크린 화면 캡쳐 단축키 (Mac Print Screen) hooni 2015.07.21 1892
1104 Develop 링크들 보고 지울 내용 secret hooni 2019.11.21 0
1103 Develop 리팩토링 계획안 file hooni 2017.05.15 737
1102 Develop 레고 마인드스톰 NXT 수도쿠, 큐브 소스코드.. 20 file hooni 2013.04.23 81376
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 98 Next
/ 98