文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

聊一聊为什么是 0x3f ?

2024-12-14 01:44

关注

首先我们看一下 0x3f 有多大。

  1. #include  
  2. #include  
  3. #include  
  4. using namespace std; 
  5.  
  6. int main() 
  7.     int a[1]; 
  8.     memset(a, 0x3f, 4); 
  9.     cout << a[0]; 

输出 1061109567 ,是10^9级别的。

memset 按照字节赋值,因此我们把 4 个 0011 1111 填充到 32 位的 int 上。但问题是,为什么不是 0x4f 或者 0x5f ?

首先 10^9 级别足够大,其次,也是最重要的,0x3f3f3f3f + 0x3f3f3f3f 等于 0x7e7e7e7e , 不会爆int 。

在很多算法中,我们需要进行诸如 dist[j] > dist[t] + w[t][j] 之类的判断,如果两个大于 0x3f3f3f3f 的数相加,那么后果不堪设想。因为溢出并不会报错,算法逻辑复杂,我们往往很难定位真正的错误。

附:近期收集了很多 C++ STL 的妙用... 如下图片的 C++ 确实有点感触。

笔记主要放在 github/PiperLiu/ACMOI_Journey[1] 的“经验”中。有空一并整理。

此外,memset 对于不同的数据类型初始值当然是不同的,有一篇极好的文章:【自用】 memset对于int、long long、float、double 的极值怎么清[2],阅读原文也可查看。比如 int 对应 0x3f, float 对应 0x4f 。

值得注意的是,我最近在看歪总代码时,用到初始化 -INF ,直接 memset(a, -0x3f, sizeof a) 也是可以的,无非就是 0x3f 取反加一嘛,从 0011 1111 变为 1100 0001 。但是相加会爆。

参考资料

[1]github/PiperLiu/ACMOI_Journey: https://github.com/PiperLiu/ACMOI_Journey

[2]【自用】 memset对于int、long long、float、double 的极值怎么清: https://blog.csdn.net/vmurder/article/details/46537613

来源:Piper蛋窝内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯