妈蛋这个坑了我大半个小时都想不出个原因。。后来看到pow的定义才想起,数据类型很重要啊。。


1.底数用常量,指数用整型

 #include <stdio.h>
#include <math.h>
int main()
{
int i,j;
for(i=;i<;i++)
{
j=pow(,i);
printf("%d\n",j);
}
return ;
}

运行结果:

1
10
99
1000
9999
100000
1000000
9999999
99999999

答案不是1000下去而是出现了9999999,一开始百撕不得其姐。。

看到定义后改用如下

2.底数用常量,指数用double

 #include <stdio.h>
#include <math.h>
int main()
{
double i,j;
for(i=;i<;i++)
{
j=pow(,i);
printf("%.0lf\n",j);
}
return ;
}

运行结果:

1
10
100
1000
10000
100000
1000000
10000000
100000000

改用double就没事了

那么指数用常量呢

3.底数用常量,指数用常量

 #include <stdio.h>
#include <math.h>
int main()
{
double i;
i=pow(,);printf("%.0lf\n",i);
i=pow(,);printf("%.0lf\n",i);
return ;
}

运行结果:

1000
10000

可见,指数用常量也是没问题的


经过n次测试,原因找出来了

再看另一组数据:

1.指数用int,pow值赋给int,结果错误

 #include <stdio.h>
#include <math.h>
int main()
{
double d;
int p,i=;
p=pow(,i);
printf("%d\n",p);
return ;
}

运行结果:

999999999

2.指数用常量,pow值赋给int,结果正确

 #include <stdio.h>
#include <math.h>
int main()
{
double d;
int p,i=;
p=pow(,);
printf("%d\n",p);
return ;
}

运行结果:

1000000000

3.指数用常量,pow值赋给double,结果正确

 #include <stdio.h>
#include <math.h>
int main()
{
double d,p;
p=pow(,9);
printf("%.0lf\n",p);
return ;
}

运行结果:

1000000000

4.指数用int,pow值赋给double,结果正确

 #include <stdio.h>
#include <math.h>
int main()
{
double d,p;
int i=;
p=pow(,i);
printf("%.0lf\n",p);
return ;
}

运行结果:

1000000000

5.指数用double,pow值赋给int,结果错误

 #include <stdio.h>
#include <math.h>
int main()
{
double d,i=;
int p;
p=pow(,i);
printf("%d\n",p);
return ;
}

运行结果:

999999999


从数据看出

pow赋值给int的时候:指数用常量,结果正确;指数用int、double,结果错误

pow赋值给double的时候,指数用常量、int、double,结果都正确


结论,指数用什么类型无关紧要,重要的是pow的值要赋给一个double型变量。

pow()函数的精度问题的更多相关文章

  1. C语言pow()函数的计算精度问题

    编程计算 a+aa+aaa+-+aa-a(n个a)的值,n和a的值由键盘输入.例如,当n=4,a=2,表示计算2+22+222+2222的值. 程序运行结果示例: Input a,n: 2,4↙ su ...

  2. pow()函数结果强制转化为int造成误差的分析

    开发环境:codeblocks,编译器gcc 在计算102时调用pow(10, 2),再强制类型转换为int类型后输出: printf(,)); 得到的结果却是:99 这是因为 double pow( ...

  3. pow函数

    pow函数如果直接强制类型转换成int,会导致精度的损失.如果是int的幂计算,建议重写函数.或者用double型进行计算.

  4. python实现pow函数(求n次幂,求n次方)

    目录 类型一:求n次幂 类型二:求n开方 类型一:求n次幂 实现 pow(x, n),即计算 x 的 n 次幂函数.其中n为整数.pow函数的实现--leetcode 解法1:暴力法 不是常规意义上的 ...

  5. C语言pow函数编写

    C语言pow函数编写 #include<stdio.h> double chaoba(double f,double q); //声明自定义函数 void main(void) { dou ...

  6. 汇编语言计算Sin,Cos,Pow函数

    填了一下之前的坑.首先是一个题外话,在VS2015中默认汇编代码会使用SSE生成,如果想用FPU编译出FLD,FSTP这些指令,需要设置一下. 项目 >> 属性 >> C/C+ ...

  7. C语言--pow()函数实现

      为什么自己实现一个pow()函数呢?昨天在Linux操作系统中调用这一个函数时,一直报错,也没有查找到具体的原因.故心血来潮实现这一函数功能. 函数所在头文件:   在"math.h&q ...

  8. Python3 pow() 函数

    Python3 pow() 函数  Python3 数字 描述 pow() 方法返回 xy(x的y次方) 的值. 语法 以下是 math 模块 pow() 方法的语法: import math mat ...

  9. 日常踩坑——Dev C++ pow()函数的坑

    坑 Dev C++ pow()函数 那年冬天,显示屏前坐着如喽啰,那时候我含泪发誓,再也不用Dev. 蓝桥杯官网给提供的版本,没办法bug也得硬着头皮用. 16年蓝桥杯的第八题 四平方和定理: 在De ...

随机推荐

  1. http协议详解-经典篇

    本文转载至 http://www.cnblogs.com/flychen/archive/2012/11/28/2792206.html   ————————————————————————————— ...

  2. 【BZOJ4653】[Noi2016]区间 双指针法+线段树

    [BZOJ4653][Noi2016]区间 Description 在数轴上有 n个闭区间 [l1,r1],[l2,r2],...,[ln,rn].现在要从中选出 m 个区间,使得这 m个区间共同包含 ...

  3. Dubbo服务集群,常见容错机制:failover ,failsafe,failfase ,failback,forking

    http://blog.csdn.net/hongweigg/article/details/52925920 http://m.blog.csdn.net/article/details?id=51 ...

  4. Wix Burn:如何将32位和64位的安装包制作成一个安装包

    由于Windows Installer不是平台独立的(即区分32-bit和64-bit),因此用Wix制作的安装包在编译不能像.net应用那样采用Any CPU编译,而必须制定是目标Platform是 ...

  5. Eclipse中servlet显示无法导入javax.servlet包问题的解决方案

    项目名-->右键 Property-->选择 JavaBuild Path-->选择 Add External JARs-->选择 把servlet-api.jar的路径输入即 ...

  6. Java拓展教程:文件DES加解密

    Java拓展教程:文件加解密 Java中的加密解密技术 加密技术根据一般可以分为对称加密技术和非对称加密技术.对称加密技术属于传统的加密技术,它的加密和解密的密钥是相同的,它的优点是:运算速度快,加密 ...

  7. ruby 字符串

    字符串处理函数 1.返回字符串的长度 str.length => integer 2.判断字符串中是否包含另一个串 str.include? other_str => true or fa ...

  8. ceres求解BA第10章

    1.前言g2o是根据边来保存每一个代价函数,它是在边类中构造误差函数,构造边的时候,会设置顶点.测量值.协方差矩阵等.而在ceres中,用problem类型来构造最终的目标函数.先是使用AddResi ...

  9. 【LeetCode】最大子序和

    给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 ...

  10. 51nod 80分算法题

    1537:见前几篇. 1627:题意:给定n,m的网格(10^5),初始状态为(1,1),你每次可以瞬移到右下方(不可以同行同列逗留)任何一个方格里,求移动到n,m的方案数. 一句话题解:首先很容易想 ...