C语言程序问题 求第1500个只有2,3,5因子的数

#include<stdio.h>voidmain(){intcnt=0;intnumber=1;while(1){if(number==1||number%2==0||... #include <stdio.h>
void main()
{
int cnt = 0;
int number = 1;
while(1)
{
if(number == 1 || number % 2 == 0 || number % 3 == 0 || number % 5 ==0 || (number % 2) % 3==0 || (number % 2) % 5 == 0 || (number % 3) % 5 == 0 || ((number % 2) % 3) % 5 == 0)
cnt++;
if(cnt == 1500)
{
sprintf("第1500个只有2.3.5因子数的数是%d",number);
break;
}
number++;
}
}
运行出错 为什么 求解释 或者提供另外一个可运行程序 悬赏分可加
展开
 我来答
问明6E
高粉答主

2019-06-18 · 每个回答都超有意思的
知道答主
回答量:279
采纳率:100%
帮助的人:12.5万
展开全部

include   <stdio.h>   

#define   N   1500   

int   main()   

{   

long   result[N];   

int   p2,p3,p5;   

int   i;   

result[0]=1;   

p2=p3=p5=0;   

for(i=1;i<N;i++){   

int   min,choice;   

min=result[p2]*2;   

if(min>result[p3]*3){min=result[p3]*3;}   

if(min>result[p5]*5){min=result[p5]*5;}   

result[i]=min;   

if(result[p2]*2<=result[i])p2++;   

if(result[p3]*3<=result[i])p3++;   

if(result[p5]*5<=result[i])p5++;   

}   

printf("%d",result[N-1]);   

}

扩展资料:

printf()函数用法:

在C语言中,有三个函数可以用来在显示器上输出数据,它们分别是:

1、puts():只能输出字符串,并且输出结束后会自动换行。

2、putchar():只能输出单个字符。

3、printf():可以输出各种类型的数据。

不愿相离
2014-11-19 · TA获得超过440个赞
知道小有建树答主
回答量:529
采纳率:0%
帮助的人:486万
展开全部

//求第1500个只有2,3,5因子的数,数是从小到大排列,第一个数是1,1=2^0*3^0*5^0

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

long number[1600];
char accFlag = 0;
long *pf2 = 0;
long *pf3 = 0;
long *pf5 = 0;

int main()
{
int n;
long max;
long next2, next3, next5;
number[1] = 1;
pf2 = pf3 = pf5 = number + 1;
next2 = 2;
next3 = 3;
next5 = 5;
for(n = 2; n <= 1500; ++n)
{
max = next2;
accFlag = 1;
if ( next3 < max )
{
max = next3;
accFlag = 2;
}
else if ( next3 == max )
{
accFlag |= 2;
}
if ( next5 < max )
{
max = next5;
accFlag = 4;
}
else if ( next5 == max )
{
accFlag |= 4;
}
number[n] = max;
if ( accFlag & 1 )
{
++pf2;
next2 = *pf2 * 2;
}
if ( accFlag & 2 )
{
++pf3;
next3 = *pf3 * 3;
}
if ( accFlag & 4 )
{
++pf5;
next5 = *pf5 * 5;
}
}
printf("第1500个只有2.3.5因子数的数是= %ld\n", number[1500]);
return 0;
}
不是自己写的,但是是正确的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
opy12
推荐于2017-12-16 · TA获得超过784个赞
知道小有建树答主
回答量:554
采纳率:0%
帮助的人:424万
展开全部

算法是对的,但是输出函数多了一个s:

sprintf("第1500个只有2.3.5因子数的数是%d"

把它改回printf就行了!!!

运行结果如下:

更多追问追答
追问
我的算法好像是出了问题了  答案不是这个
追答
答案是什么,我给你改算法!
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
风情a飞少
2014-11-19 · TA获得超过295个赞
知道小有建树答主
回答量:117
采纳率:0%
帮助的人:65.5万
展开全部
第一个数是2*3*5
第二个 2*2*3*5;
第三个 3*2*3*5;
第四个 2*2*2*3*5;
这样看来应该是第1500个数太大,长度超了
if中的条件也是有问题的
追问
用long定义 number也会超么?  条件错哪?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
十指502
2014-11-19 · TA获得超过189个赞
知道小有建树答主
回答量:203
采纳率:0%
帮助的人:149万
展开全部
#include <stdio.h>
void main()
{
int cnt = 0;
int number = 1;
while(1)
{
if(number == 1 || number % 2 == 0 || number % 3 == 0 || number % 5 ==0 || (number % 2) % 3==0 || (number % 2) % 5 == 0 || (number % 3) % 5 == 0 || ((number % 2) % 3) % 5 == 0)
cnt++;
if(cnt == 1500)
{
printf("第1500个只有2.3.5因子数的数是%d\n",number);
break;
}
number++;
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(6)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式