在使用在整型计算中,如果次方数过大,使用 pow 会出现一些问题。比如这两个代码,本质上计算是相同,并没有什么区别。#include stdio.h#include math.hint main(){long long s=0,a;for (int i=1;i=60;i++...

在使用在整型计算中,如果次方数过大,使用 pow 会出现一些问题。
比如这两个代码,本质上计算是相同,并没有什么区别。
#include <stdio.h>
#include <math.h>
int main()
{
long long s=0,a;
for (int i=1;i<=60;i++){
s+=pow(2,i-1);
}
printf("%lld",s);
return 0;
}
#include <stdio.h>
#include <math.h>
int main()
{
long long s=0,a;
for (int i=1;i<=60;i++){
a=pow(2,i-1);
s+=a;
}
printf("%lld",s);
return 0;
}
运行结果如下(不怎么会调图片大小,就放原截图了)
发现运行结果差1
调试中
在循环当中插入
printf("%d %lld\n",i,s);
发现是进行第54次循环时出现了问题
和同学讨论,发现了原因出在哪里,并解决了这个问题
C语言 pow 的原函数是 double pow,计算的结果返回的是 double,也就是双精度。
所以我们要自我设定一个关于 long long 类型的 pow 函数。
long long longpow(int x,int y)
{
int i;
long long p=1;
for (i=1;i<=y;i++){
p*=x;
}
return(p);
}
运行的前面两种方式(附代码和运行结果)
#include <stdio.h>
#include <math.h>
int main()
{
long long longpow(int x,int y);
long long s=0,a=0;
for (int i=1;i<=60;i++){
s+=longpow(2,i-1);
}
printf("%lld",s);
return 0;
}
long long longpow(int x,int y)
{
int i;
long long p=1;
for (i=1;i<=y;i++){
p*=x;
}
return(p);
}
#include <stdio.h>
#include <math.h>
int main()
{
long long longpow(int x,int y);
long long s=0,a=0;
for (int i=1;i<=60;i++){
a=longpow(2,i-1);
s+=a;
}
printf("%lld",s);
return 0;
}
long long longpow(int x,int y)
{
int i;
long long p=1;
for (i=1;i<=y;i++){
p*=x;
}
return(p);
}
这是写博客的第三次,不好请多多担待
织梦狗教程
本文标题为:C语言学习———pow的使用


基础教程推荐
猜你喜欢
- C语言 详解字符串基础 2023-03-27
- centos 7 vscode cmake 编译c++工程 2023-09-17
- 带你深度走入C语言取整以及4种函数 2022-09-17
- C语言实现宾馆管理系统课程设计 2023-03-13
- [c语言-函数]不定量参数 2023-09-08
- C++实现ETW进行进程变动监控详解 2023-05-15
- [C语言]二叉搜索树 2023-09-07
- 全面了解C语言 static 关键字 2023-03-26
- C语言编程C++旋转字符操作串示例详解 2022-11-20
- C++实战之二进制数据处理与封装 2023-05-29