19保研 7-2 Zigzag Sequence (25 分)

由题意,假如第一行是第0行,那么就是奇数行逆着输出,这个用reverse很容易实现,所以就是用k表示第几行,判断需不需要翻转,然后用t表示每一行的第一个下标,用来实现翻转的范围

#include <bits/stdc++.h>

using namespace std;

const int maxn = 10005;

int main() {
   
    int n, m, a[maxn];
    scanf("%d %d", &n
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于无符号整数0x7b,它的有符号整数表示为123。 Zigzag 编码的规则是将有符号整数左移一位,然后通过异或操作将符号位移动到最后一位。因此,对于有符号整数123,它的 Zigzag 编码结果为246(二进制表示为 11110110)。 Varint 编码的规则是将整数按照小端字节序进行拆,每个字节的最高位表示是否为最后一个字节,其余 7 位表示数据。因此,对于 Zigzag 编码结果为246的整数,它的 Varint 编码结果为 0xF6 0x01(十六进制表示,其中 0xF6 表示低 7 位数据,0x01 表示最高位为 1,即还有一个字节)。 下面是 Zigzag 和 Varint 编码的示例代码(使用 C++ 语言实现): ```cpp #include <iostream> #include <cstdint> #include <vector> // Zigzag 编码 uint32_t ZigzagEncode(int32_t n) { return (n << 1) ^ (n >> 31); } // Varint 编码 std::vector<uint8_t> VarintEncode(uint32_t n) { std::vector<uint8_t> result; while (n >= 0x80) { result.push_back((n & 0x7F) | 0x80); n >>= 7; } result.push_back(n & 0x7F); return result; } int main() { // 对无符号整数0x7b进行 Zigzag 和 Varint 编码 uint32_t n = ZigzagEncode(123); std::vector<uint8_t> varint = VarintEncode(n); // 输出编码结果 std::cout << "Zigzag 编码结果为:" << n << std::endl; std::cout << "Varint 编码结果为:"; for (const auto& b : varint) { std::cout << std::hex << static_cast<int>(b) << " "; } std::cout << std::endl; return 0; } ``` 输出结果为: ``` Zigzag 编码结果为:246 Varint 编码结果为:f6 01 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值