c语言如何判断一个变量对数值的最大表示(取最大)

本文通过介绍C语言中整数的补码表示法,探讨如何判断一个变量能表示的最大数值。通过一个循环自增运算,当变量值翻转为负数时,递减操作即可得出最大正数值。
摘要由CSDN通过智能技术生成

首先,看这个代码前,要对了解“补码”的含义
简单贴一点随堂笔记:

整数的范围

数的范围

对于一个字节(8位),可以表达的是:

00000000 - 11111111

其中

00000000 ——> 0	

1111 1111 ~ 1000 0000 ——> -1~ -128

0000 0001 ~ 0111 1111 ——>  1~127

1000 0000  . 0000 0000 .

unsigned

如果一个字面量常数想要表达自己是unsigned,可以在后面加u或者U

255U	

用l或L 表示long(long) 

unsigned 的初衷并非扩展数能表达的范围,而是为了作纯二进制运算,
//扩展正整数的表达范围

主要是为了移位

在这里插入图片描述
这张图片很好的 表示了 一个int的表示范围
其中逆时针代表加,顺时针表示减。
由此可以解释下面的代码。

具体代码如下:

#include<stdio.h>
//判断一个变量所能表达的最大数与位数
/*
判断一个变量所能表达的最大数与位数
由那个圆可知,整数范围内的最大值在12点钟
即可以:
1·通过一个循环,使一个变量作自增运算
2·循环继续条件为 该变量>0,
3·所以循环跳出时,变量值停止位置就是最大正数“翻过去”的一个负数
4·此时作–&

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值