妈蛋这个坑了我大半个小时都想不出个原因。。后来看到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. 一些重要的地址:md5在线解密破解

    md5在线解密破解:https://www.cmd5.com/

  2. Grunt学习笔记【8】---- grunt-angular-templates插件详解

    本文主要讲如何用Grunt打包AngularJS的模板HTML. 一 说明 AngularJS中使用单独HTML模板文件的地方非常多,例如:自定义指令.ng-include.templateUrl等. ...

  3. SD相关的表

    [转] 一.客户主数据基本数据放在KNA1里:公司代码放在KNB1里:销售视图放在KNVV里:合作伙伴放在KNVP里:二.信用主数据KNKK里有信贷限额.应收总额.特别往来:S066里是未清订单值:S ...

  4. spring-data-redis RedisTemplate操作

    使用RedisTemplate来对对象.String等做缓存处理 首先定义一个对象并重写toString方法 public class UserInfo implements Serializable ...

  5. Java for LeetCode 132 Palindrome Partitioning II

    Given a string s, partition s such that every substring of the partition is a palindrome. Return the ...

  6. yum安装软件出错解决方法

    造成yum下载安装时语法出错, 一般是由于python多个版本共存的原因.所以,只需将yum 设置文件固定python 版本,也就是python2 下面的操作能解决版本冲突问题. 1.sudo vim ...

  7. iOSapp内跳转到设置界面

    从app内跳转到设置界面的代码如下: NSURL *url = [NSURL URLWithString:UIApplicationOpenSettingsURLString]; if ([[UIAp ...

  8. LightOJ - 1151 Snakes and Ladders —— 期望、高斯消元法

    题目链接:https://vjudge.net/problem/LightOJ-1151 1151 - Snakes and Ladders    PDF (English) Statistics F ...

  9. Spring Boot2.0之整合Mybatis

    我在写这个教程时候,踩了个坑,一下子折腾到了凌晨两点半. 坑: Spring Boot对于Mysql8.1的驱动支持不好啊 我本地安装的是Mysql8.1版本,在开发时候.pom提示不需要输入驱动版本 ...

  10. UER#7 T2

    题意:给定n个数,对于2到n,分别输出一个答案.答案定义为:对于当前的数k,在原数组中找一个长度为k的区间,使得区间最值之差最小,输出差值.注意,差值允许5%的误差. 很少看见近似算法的题啊..跪烂V ...