输出大数
Output of large numbers
本文关键字:输出 更新时间:2023-10-16
我需要在我的程序中使用一个高数字。这里有一个最小的例子来说明这个问题。它只是读入一个数字,然后再给出这个数字。
using namespace std;
#include <iostream>
#include <stdlib.h>
int main(int argc, char* argv[])
{
double
N = atoi(argv[1]);
cout << N << endl;
return 0;
}
一切都很好,直到10^9如果我把10^10作为输入,结果是1.41007e+09。我只是不知道为什么会这样。我已经尝试了以下操作:
- 将N的数据类型更改为double, long int, unsigned int
- 直接在程序中定义N = pow(10,10)。当我直接输出N 和 pow(10,10)时,N给出了错误的值,而pow(10,10)给出了正确的值。
当结果值超出int
的范围(即大于INT_MAX
或小于INT_MIN
)时使用atoi
会导致未定义的行为。
这是不使用atoi
的一个很好的理由。C库中的备选strtol
和strtoul
对所有输入都有良好定义的行为。
c++ 11函数std::stoi
也有定义良好的行为(如果值超出范围,它会抛出异常)。istream::operator>>(int&)
也定义良好,但它有一些与流不能"向前看"有关的繁琐细节。
对大于INT_MAX的数字使用atoi将导致结果值从负值INT_MIN开始
尝试使用环礁函数。它在中。但这是在c++ 11中定义的。所以,如果你的编译器不是最新的,它会抛出一个错误。
如果该值又相当大(大于8字节),那么我建议您使用外部库
输入10^10超出了整数2147483648的最大限制,而10^9完全在限制之内。
下面的代码可能很有用。
using namespace std;
#include <iostream>
#include <stdlib.h>
int main(int argc, char* argv[])
{
long long N = atoll (argv[1]);
cout << N << endl;
return 0;
}
相关文章:
- 递归函数计算序列中的平方和(并输出过程)
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 请解释"函数1(p1,p2,p3);"的输出
- C++:将控制台输出存储在宏中更好吗
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 为什么我的代码在输出中增加了93天
- 如何从void函数输出字符串
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- AES加密到解密未正确输出
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- C++格式化输出问题
- 将值从二维数组输出到文本文件
- 集合上的输出迭代器:assign和increment迭代器
- 在while循环中输入带有std::cin的字符串后,控制台会输出大量胡言乱语
- 为什么rk4.do_step不输出C++中的初始条件
- 输出没有重复元素的动态数组(收缩数组)C++
- 如何根据单词在文本中出现的概率输出单词