平方根不等式中的陷阱与反思 c语言

题目:

        试求满足以下平方根不等式的正整数m     √m+√(m+1)+`````+√3m>100000;
错误代码:
      #include<stdio.h>
      #include<math.h>
void main()
{
int i,m;
double s=0,n;                                          
printf("Please input the number:\n");
scanf("%f",&n);
for(i=1;i<n*n;i++)
{
for(m=i;m<=3*i;m++)  {    s=s+sqrt(m); }
//printf("%d  %f\n\n\n",i,s); 

if(s>n)  {  break; }

}
printf("m>=%d, s=%f\n",i,s);

}
  上面标记的两处红色即为出错地方。改正如下
#include<stdio.h>
#include<math.h>
void main()
{
int i,m;
double s,n;
printf("Please input the number:\n");
scanf("%lf",&n);
for(i=1;i<n*n;i++)
{
s=0;
for(m=i;m<=3*i;m++)  {    s=s+sqrt(m); }
//printf("%d  %f\n\n\n",i,s); 

if(s>n)  {  break; }

}
printf("m>=%d, s=%f\n",i,s);

}
 第一:s=0;要放在第一层循环里面,原因稍微想一想就知道了。
第二:scanf对于输入是double类型的格式。我在网上找了一下,感觉说的很好。以下是摘录
  http://book.51cto.com/art/200901/106880.htm   这个是链接地址
           对于double类型的数据,在printf中要用%f,在scanf中必须用%lf,否则就要运行结果就不对。正如以上程序一样。
            printf的%f说明符的确既可以输出float型又可以输出double型。 根据"默认参数提升"规则(在printf这样的函数的可变参数列表中 ,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到双精度数。
         对于scanf,情况就完全不同了,它接受指针,这里没有类似的类型提升。(通过指针)向float存储和向double存储大不一样,因此,scanf区别%f和%lf。
      
       

           

         

 (严格地讲,%lf在printf下是未定义的,但是很多系统可能会接受它。要确保可移植性,就要坚持使用%f。)

  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值