华为OD机试 - 整数编码(Java 2024 E卷 100分)

这篇博客介绍了华为OD机试中的一道整数编码题目,详细解析了编码规则和解题思路。算法以7位一组,使用补码表示,最高位标记后续字节存在。Java实现中,先将输入的非负整数转换为二进制,再按照编码规则处理并转换为16进制输出。文章提供了输入输出示例及完整Java代码。

一、题目描述

实现一个整数编码方法,使得待编码的数字越小,编码后所占用的字节数越小。

编码规则如下:

  1. 编码时7位一组,每个字节的低7位用于存储待编码数字的补码;
  2. 字节的最高位表示后续是否还有字节,置1表示后面还有更多的字节,置0表示当前字节为最后一个字节;
  3. 采用小端序编码,低位和低字节放在低地址上;
  4. 编码结果按16进制数的字符格式进行输出,小写字母需要转化为大写字母。

二、输入描述

输入的为一个字符串表示的非负整数。

三、输出描述

输出一个字符串表示整数编码的16进制码流。

四、测试用例

测试用例1

1、输入

127

2、输出

7F

3、说明

127 的二进制为 1111111,编码时需补高位为0,最终字节为 01111111(十六进制 7F)。

测试用例2

1、输入

128

2、输出

801

3、说明

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哪 吒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值