当前位置: 首页 > news >正文

编程计算int类型整数的最大值和最小值

方法一:将一个int类型整数不断加1,加到最大值,再加1,就变成负值(最小值)

 最大值就是除最高位外,其余位都为1,-1即是所有位全部是1,右移1位后最高位变0
   最小值即是最高位为1,其余位为0,所以最大值+1之后就变成了最小值

//#include <stdio.h>
#include <iostream>
//#include <limits.h>

using namespace std;

int main(){
    int i = 0, min, max;
    while(1){
        if(i+1<=0){
            max = i;
            min = i+1;
            break;
        }
        i++;
    }
    cout << "min is " << min <<endl;
    cout << "max is " << max << endl;
    getchar();
    return 0;
}

方法二:利用标准头文件limits.h,该文件包含一些很有用的常量,它们定义了各种类型所能容纳的值,其中int类型最大值最小值的预定义为

#define INT_MAX 2147483647
#define INT_MIN (-INT_MAX-1)
所以可以利用此头文件打印int类型整数的最小值和最大值。
//#include <stdio.h>
#include <iostream>
#include <limits.h>

using namespace std;

int main(){
    cout << "最小值是:" << INT_MIN << endl;
    cout << "最大值是:" << INT_MAX << endl;
    getchar();
    return 0;
}

 

方法三:C++模板numeric_limits(对模板不熟悉啊)可以参考:

http://blog.163.com/wujiaxing009@126/blog/static/7198839920124135147911/

代码:

#include <iostream>
#include <limits>
using namespace std;

int main(){
    cout<<(numeric_limits<int>::max)()<<endl;
    cout<<(numeric_limits<int>::min)()<<endl;
    cout<<(numeric_limits<size_t>::max)()<<endl;
    cout<<(numeric_limits<size_t>::min)()<<endl;
    cout<<(numeric_limits<float>::max)()<<endl;
    cout<<(numeric_limits<float>::min)()<<endl;
    cout<<(numeric_limits<double>::max)()<<endl;
    cout<<(numeric_limits<double>::min)()<<endl;
    getchar();
    return 0;
}

以上是在网上看到的三种方法,学习学习。

 

转载于:https://www.cnblogs.com/gkfeng/p/4573351.html

相关文章:

  • java.lang.ClassNotFoundException: org.junit.Assume$AssumptionViolatedException
  • ofbiz中的container-1
  • CI框架分页类代码
  • 我的菜鸟之路
  • 软件需求规格说明书
  • Windows Server 2012 R2 DirectAccess功能测试(2)App1服务器安装及配置
  • Spark RDD Persistence
  • atitit.高级编程语言的特性 and 未来趋势与进化.doc
  • WindowsServer 2008 AD搭建FTP隔离用户
  • [华为机试练习题]13.火车进站
  • FlowLayout浮动布局
  • [转]Spring MVC 中的基于注解的 Controller
  • 该项目的建设maven片:4.协调和依赖,spring依赖注入demo
  • jQuery 弹出窗口的形式一直是具体案件的中心
  • 收集的一些链接
  • go append函数以及写入
  • golang 发送GET和POST示例
  • HTML5新特性总结
  • Javascripit类型转换比较那点事儿,双等号(==)
  • java小心机(3)| 浅析finalize()
  • js中的正则表达式入门
  • LeetCode541. Reverse String II -- 按步长反转字符串
  • React-flux杂记
  • Sass 快速入门教程
  • windows下如何用phpstorm同步测试服务器
  • zookeeper系列(七)实战分布式命名服务
  • 关于 Linux 进程的 UID、EUID、GID 和 EGID
  • 名企6年Java程序员的工作总结,写给在迷茫中的你!
  • 《TCP IP 详解卷1:协议》阅读笔记 - 第六章
  • ​LeetCode解法汇总2304. 网格中的最小路径代价
  • ​什么是bug?bug的源头在哪里?
  • ​一文看懂数据清洗:缺失值、异常值和重复值的处理
  • #ifdef 的技巧用法
  • (173)FPGA约束:单周期时序分析或默认时序分析
  • (Python第六天)文件处理
  • (Redis使用系列) SpirngBoot中关于Redis的值的各种方式的存储与取出 三
  • (附源码)spring boot球鞋文化交流论坛 毕业设计 141436
  • (附源码)springboot宠物医疗服务网站 毕业设计688413
  • (附源码)springboot炼糖厂地磅全自动控制系统 毕业设计 341357
  • (附源码)springboot优课在线教学系统 毕业设计 081251
  • (免费领源码)python#django#mysql公交线路查询系统85021- 计算机毕业设计项目选题推荐
  • (一)u-boot-nand.bin的下载
  • (转)甲方乙方——赵民谈找工作
  • (转)自己动手搭建Nginx+memcache+xdebug+php运行环境绿色版 For windows版
  • .NET Core SkiaSharp 替代 System.Drawing.Common 的一些用法
  • .Net Web窗口页属性
  • .net 使用$.ajax实现从前台调用后台方法(包含静态方法和非静态方法调用)
  • .net 中viewstate的原理和使用
  • .NET国产化改造探索(一)、VMware安装银河麒麟
  • .NET中GET与SET的用法
  • @ 代码随想录算法训练营第8周(C语言)|Day57(动态规划)
  • @cacheable 是否缓存成功_Spring Cache缓存注解
  • @SuppressWarnings(unchecked)代码的作用
  • [ 数据结构 - C++] AVL树原理及实现
  • [2013][note]通过石墨烯调谐用于开关、传感的动态可重构Fano超——