0x3f3f3f3f是什么意思???

ACM中常用的无穷大常量——0x3f3f3f3f

最近做题看题解的时候发现在大佬的题解报告中常会出现这么一行:↓↓↓

const int inf = 0x3f3f3f3f;

然后我就去探索了一下,0x3f3f3f3f的十进制是1061109567,是10^9级别的,而一般场合下的数据都是小于10^9的,所以它可以作为无穷大使用而不致出现数据大于无穷大的情形。 

一般dfs或者dp求最小值的问题中间会出现一些不存在的情况,我一般会采用一种方法就是返回一个很大的值,这样去最小的时候就不会取到这种情况了(不知道是不是专业做法),我一般在取这个“很大的值”的时候会选一个答案不可能的值,比如bfs求最短路一共是一个10000层的树,就取一个10005。

而宏定义一个0x3f3f3f3f可以减少考虑的时间,一般情况下就可以当作是一个无穷大的数去用。

引用一段别人的博客中的介绍:

0x3f3f3f3f是一个很有用的数值,它是满足以下两个条件的最大整数。

1、整数的两倍不超过 0x7f7f7f7f,即int能表示的最大正整数。

2、整数的每8位(每个字节)都是相同的。

我们在程序设计中经常需要使用 memset(a, val, sizeof a) 初始化一个数组a,该语句把数值 val(0x00~0xFF)填充到数组a 的每个字节上,所以用memset只能赋值出“每8位都相同”的 int。

当需要把一个数组中的数值初始化成正无穷时,为了避免加法算术上溢出或者繁琐的判断,我们经常用 memset(a, 0x3f, sizeof(a)) 给数组赋 0x3f3f3f3f的值来代替。

也可以参考这个:https://blog.csdn.net/jiange_zh/article/details/50198097

你可能感兴趣的:(其他)