USACO 3.1 Humble Numbers 丑数

  从这一题开始,, 以后题目我就不贴上来了... 自己去看吧..
  这一题开始肯本看不懂,, 后来是反反复复看标程看懂了..
  首先要理解这么一个式子吧(算是式子吧``)
  已经求出了j-1个丑数,, 现在求第j个丑数
  对于每一个素数p乘以一个最小的丑数, 能使积大于第j-1个丑数
    在这些乘积中寻找最小的一个即位第j个丑数.

  用pindex[i]表示对于第i个素数乘以的最小丑数是多少..
/*
LANG: C
ID: zqy11001
PROG: humble
*/
#include <stdio.h>
#include <string.h>
#define MAX 100
#define getint(i) scanf("%d", &i)
#define insert(i) hum[count++] = i

long hum[1000001];
int pindex[MAX];
int prime[MAX];
int count;

int main(void)
{
int k, n;
int i;
int min, m;
freopen("humble.in", "r", stdin);
freopen("humble.out", "w", stdout);
getint(k);
getint(n);
for(i = 0; i < k; i++){
getint(prime[i]);
}

insert(1);
memset(pindex, 0, sizeof(int)*k);
while(count <= n){
min = 0x7FFFFFFF;
for(i = 0; i < k; i++){
while(prime[i] * hum[pindex[i]] <= hum[count - 1]){
pindex[i]++;
}

if(prime[i] * hum[pindex[i]] < min){
min = prime[i] * hum[pindex[i]];
m = i;
}
}
insert(min);
}

printf("%d\n", hum[n]);
return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值