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 等类型无法使用。
  • 不够通用:如果需要处理其他类型或复杂数据结构时,代码的可扩展性较差。
相关推荐
yanqiaofanhua12 分钟前
C语言自学--数据在内存中的存储
c语言·开发语言
玖笙&2 小时前
✨WPF编程基础【1.3】:XAML 名称空间
c++·wpf·visual studio
玖笙&2 小时前
✨WPF编程基础【1.4】:类型转换器(含示例及源码)
c++·wpf·visual studio
计算机软件程序设计3 小时前
基于Python的二手车价格数据分析与预测系统的设计与实现
开发语言·python·数据分析·预测系统
微笑尅乐4 小时前
力扣350.两个数组的交集II
java·算法·leetcode·动态规划
꒰ঌ 安卓开发໒꒱5 小时前
Java面试-并发面试(二)
java·开发语言·面试
比特森林探险记5 小时前
Golang面试-Channel
服务器·开发语言·golang
xiangzhihong85 小时前
Spring Boot实现文字转语音功能
开发语言·python
月夕·花晨5 小时前
Gateway-断言
java·开发语言·分布式·spring cloud·微服务·nacos·sentinel
西贝爱学习6 小时前
【JDK 11 安装包免费下载 免登录Oracle 】jdk11与jdk8有什么区别?
java·开发语言