/*
2016年12月20日23:01:47
幸运数统计
*/
# include<stdio.h>
# define MAX 50000
int create_luck(int * );
int num_luck(int *,int,int,int);
int main(void)
{
int luck[MAX] = {0};
int max,n,i;
int num1,num2;/*标定范围*/
max = create_luck(luck);/*幸运数生成*/
scanf("%d%d",&num1,&num2);
n = num_luck(luck,max,num1,num2);/*计算num1到num2之间的幸运数个数*/
printf("%d\n",n);
/*for(i=0;i<max;i++){
printf("%d\t",luck[i]);//遍历幸运数
}*/
return 0;
}
int create_luck(int * luck)
{
/*1~2*MAX的幸运数*/
int i,j;
int point_pre=1;/*point_pre用来标记被除数数组下标,也就是上一次循环找到的幸运数*/
int point_max=MAX;/*point_max用来标记遍历一遍完成删除之后剩余的元素个数*/
/*原始奇数数组,第一次将偶数完全删除,所以所有幸运数在奇数中生成即可*/
for(i=0;i<MAX;i++){
luck[i] = 2*i+1;
}
/*生成幸运数*/
while(point_pre < point_max){
for(j = point_pre, i = point_pre; j<point_max; j++){/*i,j从point_pre开始,因为point_pre之前的数都已经是幸运数了*/
if((j+1) % luck[point_pre] != 0){
luck[i] = luck[j];
i++;
}
}
point_pre++;/*幸运数个数加1,也是内层循环初始值后移1*/
point_max = i;/*便遍历一遍之后,i之前的符合局部条件(取余不为0),point_max则划分界限*/
}
/*注意:循环完成时,point_pre之前的数都是幸运数,
但是数组定义长为MAX,point_max之后的数(MAX-point_pre个)是无用的
*/
return point_max;
}
int num_luck(int * luck,int max,int num1,int num2)
{
int i,n=0;
for(i=0;i < max;i++){/*i<point_max是为了确保不会找到无用的数组后半部分*/
if(luck[i] >= num2)
break;
else if(luck[i] > num1)/*不包含num1和num2*/
n++;
}
return n;
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有