输出:
E807
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
说明 1000的二进制表示为0011 1110 1000,至少需要两个字节进行编码;
第一个字节最高位置1,剩余的7位存储数字1000的第一个低7位 (1101000),所以第一个字节的二进制为1110 1000,即E8;
第二个字节最高位置0,剩余的7位存储数字1000的第二个低7位 (0000111),所以第一个字节的二进制为0000 0111,即07;
采用小端序编码,所以低字节E8输出在前,高字节07输出在后。
python解法
- 解题思路:
- 该问题是将一个整数编码为变长的字节序列,其中每个字节的最高位是一个标志位,表示后续字节是否存在。具体来说,使用7位来表示数值,剩余的1位用作标志位来表示是否还有后续字节。每次编码后,若数值还大于等于128(即7位无法完全表示),则需要继续编码。最终返回的结果是这些字节的十六进制表示。
对于每个数值,取低7位作为当前字节的值(通过与0x7F按位与操作获得),然后将这个字节的最高位设为1(通过按位或操作),表示后续还有字节。
当数值变小到小于128时,停止编码,将其直接以十六进制格式返回
def encode_number(num):
res = []
while num >= 128:
res.append(f"{(num & 0x7F) | 0x80:02X}")
num >>= 7
res.append(f"{num:02X}")
return "".join(res)
num = int(input())
print(encode_number(num))
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
java解法
- 解题思路
- 该问题是将一个 long 类型的整数编码为变长的字节序列,其中每个字节的最高位是一个标志位,用来表示是否还有后续字节。每个字节的低7位用来表示数值的部分。根据编码规则,处理的过程如下:
每个字节的构成:
对于一个整数,将其分解为多个字节。每个字节表示 7 位数值,最高位(即第8位)用作标志位,表示后续是否还有字节。如果某个字节的最高位是 1,说明后面还有字节。如果是 0,表示这是最后一个字节。
过程:
将整数按 7 位拆分。
对于每个拆分出来的部分,设置其最高位为 1(表示后面还有字节)直到没有更多的数值需要编码。
当数值小于 128 时,设置该字节的最高位为 0,表示这是最后一个字节。
通过按位操作,逐步提取每个字节,并拼接结果。
编码输出:
编码后的结果是一个十六进制的字符串,表示每个字节
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
long val = in.nextLong();
Encoder enc = new Encoder();
System.out.println(enc.encode(val));
}
}
class Encoder {
public String encode(long val) {
StringBuilder sb = new StringBuilder();
boolean cont = true;
while (cont) {
int num = (int) (val & 0x7F);
val >>>= 7;
if (val != 0) {
num |= 0x80;
} else {
cont = false;
}
sb.append(String.format("%02X", num));
}
return sb.toString();
}
}
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
C++解法
- 解题思路
- 该问题的目标是将一个给定的 long long 类型整数编码成一个变长字节流,每个字节由7位数据和1位标志位组成。具体规则是:
字节格式:每个字节的最低7位用来存储数据,而最高1位用来作为标志位,表示是否还有后续字节。如果最高位为 1,表示还有更多字节;如果为 0,表示没有后续字节。
拆分流程:
将整数转换为二进制字符串。
按照每7位一组将其拆分。
对每一组数据,若不为最后一组,则设置最高位为 1,表示后续还有字节;否则,设置为 0,表示结束。
结果表示:将每个字节转为十六进制字符串,并拼接成最终的编码结果
#include
#include
#include
#include
#include
using namespace std;
string getHexString(const string &binStr) {
int hexValue = stoi(binStr, nullptr, 2);
stringstream ss;
ss << hex << uppercase << setw(2) << setfill('0') << hexValue;
return ss.str();
}
string getResult(long long num) {
string bin = bitset<64>(num).to_string();
bin = bin.substr(bin.find('1'));
stringstream ans;
int end = bin.length();
while (end - 7 > 0) {
ans << getHexString("1" + bin.substr(end - 7, 7));
end -= 7;
}
if (end > 0) {
ans << getHexString(bin.substr(0, end));
}
return ans.str();
}
int main() {
long long num;
cin >> num;
cout << getResult(num) << endl;
return 0;
}
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
C解法
更新中
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
JS解法
字节构成:
每个字节包含 7 位数据(低7位)和 1 位标志位(最高位)。
若当前字节的标志位为 1,表示后续还有字节需要编码;若为 0,表示当前字节是最后一个字节。
编码过程:
将输入的整数转为 BigInt 类型(处理大整数)。
使用 while 循环按 7 位拆分整数,并为每个字节设置标志位。
将所有字节转换为十六进制,并拼接成最终的结果。
输出:
返回变长编码的十六进制字符串,确保每个字节都以两位十六进制表示(不足两位前补零)
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
rl.on("line", (line) => {
console.log(encodeNumber(line));
});
function encodeNumber(numStr) {
let num = BigInt(numStr);
const result = [];
while (num > 0) {
let byte = Number(num & 0x7Fn);
num >>= 7n;
if (num > 0) {
byte |= 0x80;
}
result.push(byte);
}
if (result.length === 0) {
result.push(0);
}
return result.map(byte => byte.toString(16).padStart(2, '0').toUpperCase()).join("");
}
class="hljs-button signin active" data-title="登录复制" data-report-click="{"spm":"1001.2101.3001.4334"}">
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
注意:
如果发现代码有用例覆盖不到的情况,欢迎反馈!会在第一时间修正,更新。
解题不易,如对您有帮助,欢迎点赞/收藏
评论记录:
回复评论: