hdu 1058 Humble Numbers(构造?枚举?)

题意:

一个数的质因子如果只是2,3,5,7中的若干个。则这个数叫做humble number。

例如:1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 14, 15, 16, 18, 20, 21, 24, 25, 27, ...

给n,问第n个humble number是多少。

 

思路:

所有的humble数的构造都是:(2^a)*(3^b)*(5^c)*(7^d)。a,b,c,d大于等于0。

X=a+b+c+d代表这个数是第X个humble数。

假设前i-1个humble数已经求出来了,第i个humble数如何求呢?

一定是前i-1个humble数中的某个humble数乘以2或乘以3或乘以5或乘以7得到的。

好了,枚举前i-1个humble数,找出大于第i-1个humble数并且是最小,那么它就是第i个humble数了。

看代码

 

代码:

ll a[5850];
int cn=0;

int main(){

    a[1]=1;
    cn=1;

    while(cn<5842){
        ll ans=INF;
        ll temp;
        rep(i,1,cn){
            temp=a[i]*2;    if(temp>a[cn]) ans=min(ans,temp);
            temp=a[i]*3;    if(temp>a[cn]) ans=min(ans,temp);
            temp=a[i]*5;    if(temp>a[cn]) ans=min(ans,temp);
            temp=a[i]*7;    if(temp>a[cn]) ans=min(ans,temp);
        }
        a[++cn]=ans;
    }

    int n;
    while(scanf("%d",&n),n){
        int t=n%10;
        if(t==1 && n%100!=11){
            printf("The %dst humble number is ",n);
        }
        else if(t==2 && n%100!=12){
            printf("The %dnd humble number is ",n);
        }
        else if(t==3 && n%100!=13){
            printf("The %drd humble number is ",n);
        }
        else{
            printf("The %dth humble number is ",n);
        }
        printf("%I64d.\n",a[n]);
    }

    return 0;
}

 

posted @ 2015-01-24 22:29  fish7  阅读(149)  评论(0编辑  收藏  举报