C++ 中的最大值和最小值判断

1. 使用 std::numeric_limits<T>::max()std::numeric_limits<T>::min()

std::numeric_limits 是 C++ 标准库中的模板类,用于获取各种数据类型的最大值和最小值。它提供了一种通用的方式,适用于所有标准数据类型(如 intlongfloatdouble 等)。

  • 获取最大值

    cpp 复制代码
    #include <limits>
    std::numeric_limits<int>::max();  // int 类型的最大值
    std::numeric_limits<long>::max(); // long 类型的最大值
    std::numeric_limits<float>::max(); // float 类型的最大值
  • 获取最小值

    cpp 复制代码
    #include <limits>
    std::numeric_limits<int>::min();  // int 类型的最小值
    std::numeric_limits<long>::min(); // long 类型的最小值
    std::numeric_limits<float>::min(); // float 类型的最小值
优点
  • 通用性强:适用于所有数据类型。
  • 跨平台兼容性:可以处理不同平台和编译器的差异。
缺点
  • 每次需要调用 std::numeric_limits,代码稍微冗长。

2. 使用预定义常量(如 INT_MIN, INT_MAX

<climits> 头文件中,C++ 定义了一些常量,表示 int 类型和其他基础数据类型的最小值和最大值。

  • INT_MAXINT_MIN :分别表示 int 类型的最大值和最小值。
  • LONG_MAXLONG_MIN :分别表示 long 类型的最大值和最小值。
常量
cpp 复制代码
#include <climits>

INT_MAX  // int 类型的最大值
INT_MIN  // int 类型的最小值
LONG_MAX // long 类型的最大值
LONG_MIN // long 类型的最小值
优点
  • 代码简洁,直接使用常量即可。
  • 适用于 intlong 类型,无需调用额外的函数。
缺点
  • 类型局限性 :只能用于基本的整数类型,对于 floatdouble 等类型无法使用。
  • 不够通用:如果需要处理其他类型或复杂数据结构时,代码的可扩展性较差。
相关推荐
AI进化营-智能译站13 分钟前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
iCxhust16 分钟前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
晨曦夜月21 分钟前
map与unordered_map区别
算法·哈希算法
Morwit22 分钟前
QML组件之间的通信方案(暴露子组件)
c++·qt·职场和发展
qeen8735 分钟前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
莎士比亚的文学花园38 分钟前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
图码1 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
U盘失踪了1 小时前
python curl转python脚本
开发语言·chrome·python
charlie1145141911 小时前
Linux 字符设备驱动:cdev、设备号与设备模型
linux·开发语言·驱动开发·c
handler011 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法