[英]How would you set a variable to the largest number possible in C?
如何在C中将变量设置为等于无穷大(或任何保证的最大数值)?
#include <limits.h>
int x = INT_MAX;
编辑:在提问者澄清之前回答,我只是猜测他们想要什么类型。
有一个名为limits.h的文件(至少在Linux上有),它拥有这种定义,例如
/* Maximum value an `unsigned short int' can hold. (Minimum is 0.) */
# define USHRT_MAX 65535
/* Minimum and maximum values a `signed int' can hold. */
# define INT_MIN (-INT_MAX - 1)
# define INT_MAX 2147483647
/* Maximum value an `unsigned int' can hold. (Minimum is 0.) */
# define UINT_MAX 4294967295U
到目前为止,获取无符号整数类型的最大值的最简单方法是将(-1)转换为该类型。 标准(§6.2.5/ 9)要求无符号数学以大于可以表示的最大值的数字模数执行,因此对于任何无符号类型T
,表达式((T)-1)
必然是该类型中可能的最大值。
另一种获取整数最大值的可移植方法:
unsigned int uMax = (unsigned int)~0;
signed int iMax = (unsigned int)~0 >> 1;
~0
- >将所有位设置为1 >> 1
- >通过将所有位向右移位一个位置来擦除符号位 (unsigned int)
在位反转之后将~0U
(unsigned int)
转换为unsigned而不是使用~0U
,因为C没有short的后缀,char文字(一般都比int小) 因此,对于最大可能的char
值 - 只需将公式类型转换为unsigned char等。
只需在max signed int expression中再次反转所有位:
signed int iMin = ~((unsigned int)~0 >> 1);
这将第一个符号位设置为1,其余位设置为零
根据你的注释,你需要一个unsigned int
(虽然你说“无符号整数”,所以也许你想要一个整数值,不一定是unsigned int
)。
在C中,对于无符号整数类型,当转换为该类型时,值-1
保证为该类型的最大值:
size_t size_max = -1;
unsigned int uint_max = -1;
unsigned long ulong_max = -1;
分别将值SIZE_MAX
, UINT_MAX
和ULONG_MAX
分配给变量。 通常,您应该包含limits.h
并使用适当的宏,但很高兴知道上面的规则。 另外, SIZE_MAX
不在C89中,所以size_t size_max = -1;
将在C89以及C99中工作。
请注意,仅对无符号整数类型保证溢出行为。
由于这个问题上有一个C ++标签,我建议使用numeric_limits:
#include <limits>
unsigned x = std::numeric_limits<unsigned>::max();
通常这是通过1.0/0.0
完成的,但是你可能会收到编译警告。 我不知道在C89中使用其他可移植方法,但C99在math.h
有宏FP_INFINITE
。
编辑:显然Sam实际上并不想要无穷大,而是整数限制,可以在limits.h
找到,就像其他人所说的那样。
我通常使用limits.h
INT_MAX
的* _MAX
宏来表示整数等。这些宏将始终为变量类型正确设置。 即使是明确大小的类型(如uint32)也会在此头文件中包含相应的条目。
这具有作为该类型的变量可以容纳的最大可能值的优点。
对于您在问题中要求的无符号整数,您将使用UINT_MAX
我想你可能想看看这个链接:
http://www.gnu.org/s/libc/manual/html_node/Infinity-and-NaN.html
我这样做了,它在gcc 4.4.1上工作正常
#include "math.h"
int main(int argc, char**argv)
{
int x = INFINITY;
return 0;
}
#include<math.h> //the header file which need to be included// int a=INT_MAX; //Suppose "a" be that integer whose value you want largest//
#include<math.h> //the header file which need to be included// int a=INT_MAX; //Suppose "a" be that integer whose value you want largest//
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.