【C++】详解 INT_MAX 和 INT_MIN(INT_MAX 和 INT_MIN是什么?它们的用途是什么?如何防止溢出?)

sunny-ll 2024-07-08 13:35:01 阅读 62

目录

一、前言

 二、什么是 INT_MAX 和 INT_MIN ?

三、INT_MAX 和 INT_MIN 的用途 

四、如何避免溢出问题出现 ?

 五、 INT_MAX 和 INT_MIN 的运算

 六、leetcode 常考面试题

 七、共勉


一、前言

    大家在平时刷 leetcode 的时候,肯定会碰到 溢出问题 ,之后查看题解,大部分题解都会通过 INT_MAX 和 INT_MIN 来进行解决。那么为了弄清楚什么是 INT_MAX 和 INT_MIN ,我们收集了一些资料,总结如下哦!!

 二、什么是 INT_MAX 和 INT_MIN ?

     INT_MAX  和  INT_MIN 是 C++ 的两个预定义宏,代表了整型变量能够存储的最大正整数和最小负整数,分别为 2147483647 和 -2147483648。这两个宏在头文件 <climits> 中定义。

    INT_MAX 表示一个 32 位符号整数所能够表示的最大值,也就是 2^31 − 1。而 INT_MIN 则表示最小的负整数。这个值是相对于二进制补码表示法的,也就是说,负数的范围比正数大 1。

代码示例: 

#include <iostream>

#include <climits>

using namespace std;

int main()

{

int max_int = INT_MAX;

int min_int = INT_MIN;

cout << "The maximum value that can be stored in an int variable is: " << max_int << endl;

// 2147483647

cout << "The minimum value that can be stored in an int variable is: " << min_int << endl;

// -2147483648

return 0;

}

 【注意】:这些宏仅适用于 32 位整型变量,如果使用 64 位整型变量,需要使用其他预定义宏,如 <code>LONG_LONG_MAX  和 LONG_LONG_MIN,代表能够存储的最大/最小长整数。

三、INT_MAX 和 INT_MIN 的用途 

 INT_MAX 是个很大的数,如果想得到数组中最小值,可以先将 min1(下方代码中的一个变量)设成 INX_MAX,这样就不需要 const int 定义一个很大的数了:

int min1 = INT_MAX;

for(int i = 0; i < n; i++)

{

if(arr[i] < min1)

{

min1 = arr[i];

}

}

四、如何避免溢出问题出现 ?

  【C/C++】中常量 INT_MAX 和 INT_MIN 分别表示最大、最小整数 。 INT_MAX , INT_MIN 数值大小因为int占4字节32位,根据二进制编码的规则,INT_MAX = 2^31-1,INT_MIN= -2^31。C/C++中,所有超过该限值的数,都会出现溢出,出现 warning,但是并不会出现error。如果想表示的整数超过了该限值,可以使用长整型 long long 占8字节64位。

 五、 INT_MAX 和 INT_MIN 的运算

C/C++ 语言中 int 类型是 32 位的,范围是 -2147483648 到 2147483647 。 

最轻微的上溢是 INT_MAX + 1,结果是 INT_MIN。最严重的上溢是 INT_MAX + INT_MAX,结果是 -2。最轻微的下溢是 INT_MIN - 1,结果是是 INT_MAX。最严重的下溢是 INT_MIN + INT_MIN,结果是 0 。

 六、leetcode 常考面试题

题目:整数反转

链接:整数反转

<code>class Solution {

public:

int reverse(int x)

{

// to_string 函数的主要作用是将 整形 转换为 字符串

string s = to_string(x);

int l = 0;

// 考虑 负数

if(s[l]=='-')

{

l++;

}

// 将 数据部分 进行反转

std::reverse(s.begin()+l,s.end());

// INT_MAX 和 INT_MIN 是C++内置的常量

const int k1 = INT_MAX,k2 = INT_MIN;

string t1 = to_string(k1),t2 = to_string(k2);

if(s[0]=='-')

{

if(s.size()==t2.size() && s > t2)

{

return 0;

}

}

else

{

if(s.size()==t1.size() && s > t1)

{

return 0;

}

}

// stoi() 将字符串转换为 整形

x = stoi(s);

return x;

}

};

 七、共勉

  以下就是我对 详解 INT_MAX 和 INT_MIN 的理解,如果有不懂和发现问题的小伙伴,请在评论区说出来哦,同时我还会继续更新对C++  vector 类的理解,请持续关注我哦!!! 



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。