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

宁波网站建设的过程实施网站推广的最终目的

宁波网站建设的过程,实施网站推广的最终目的,电子商务网站开发的课程介绍,合肥专业网站排名推广时间限制:C/C 1000MS,其他语言 2000MS 内存限制:C/C 256MB,其他语言 512MB 难度:困难 数据解码 指定有一段经过编码的二进制数据,数据由0个或多个"编码单元"组成。"编码单元"的编码方式…
时间限制:C/C++ 1000MS,其他语言 2000MS
内存限制:C/C++ 256MB,其他语言 512MB
难度:困难

数据解码

指定有一段经过编码的二进制数据,数据由0个或多个"编码单元"组成。"编码单元"的编码方式存在如下两种:

1简单编码单元如下所示,其中:

  • TAG所占长度须为1字节,其值须为0xF0
  • SINGLE-VALUE的长度定为4字节

image.png

2.复杂编码单元如下所示,其中:

  • TAG所占长度须为1字节,其值须为0xF1
  • REPEAT所占长度固定为1字节,用于指示值在解码后消息中重复的次数
  • LEN所占长度固定为4字节,用于指示值的字节数,LEN使用大端序表示
  • 值部分必须由0个或多个"编码单元"组成,且长度必须为LEN字设所指示的字节数

image.png

编码后的数据必须完全符合上述两个原则,不允许有任何冗余的字节,请构造符合上述规则的10个编码:

请根据上述规则对一段编码后的数据进行校验,如果完全符合上述约束则输出解码后的长度,否则输出-1

输入描述

输入一行编码后的二进制数据,按字节16进制表示,如

F0 00 08 09 00

表示一串5字节的编码后数据

输入的字节数n,0<=n<=100000

输出描述

输出解码后的值的字节数,不符合约束返回-1

用例输入 1 

F1 02 00 00 00 05 F0 01 02 03 04

用例输出 1 

8

用例输入 2 

F1 01 00 00 00 04 F0 01 05

用例输出 2 

-1

提示

样例1解释:该码流存在一个复杂编码单元,其中包含一个简单编码单元(内容4字节),复杂编码单元的重复数为2,所以解码后的总长度为8字节

样例2解释:第一个编码单元为复杂编码单元,重复数为1,长度为6,其中的内容从第一个字节开始为一个简单编码单元,但简单编码单元后存在数据0303既不属于简单编码单元,也不属于复杂编码单元,为冗余数据,整体数据不合法,应输出-1

#include <iostream>
#include <vector>
#include <cstdint>using namespace std;// Helper function to parse a single encoding unit
pair<int, int> parseUnit(const vector<uint8_t>& data, int index) {if (index >= data.size()) {return {-1, -1}; // Invalid input}uint8_t tag = data[index];index++;if (tag == 0xF0) {// Simple encoding unit: 1 byte TAG + 4 bytes SINGLE-VALUEif (index + 4 > data.size()) {return {-1, -1}; // Not enough bytes for SIMPLE-VALUE}return {index + 4, 4}; // Move past the SIMPLE-VALUE and return decoded length} else if (tag == 0xF1) {// Complex encoding unit: 1 byte TAG + 1 byte REPEAT + 4 bytes LEN + LEN bytes contentif (index + 5 > data.size()) {return {-1, -1}; // Not enough bytes for REPEAT and LEN}uint8_t repeat = data[index];index++;// Read LEN (4 bytes, big-endian)uint32_t len = 0;for (int i = 0; i < 4; ++i) {len = (len << 8) | data[index++];}// Check if we have enough bytes for the contentif (index + len > data.size()) {return {-1, -1}; // Not enough bytes for the content}// Parse the content recursivelyint contentStart = index;int totalDecoded = 0;while (index < contentStart + len) {auto [newIndex, decodedLen] = parseUnit(data, index);if (newIndex == -1) {return {-1, -1}; // Invalid content}index = newIndex;totalDecoded += decodedLen;}// Ensure no extra bytes in the contentif (index != contentStart + len) {return {-1, -1}; // Extra bytes found}return {index, totalDecoded * repeat};} else {// Invalid TAGreturn {-1, -1};}
}// Main function to decode the length
int decodeLength(const vector<uint8_t>& data) {auto [index, decodedLen] = parseUnit(data, 0);// Ensure all bytes are consumedif (index == static_cast<int>(data.size())) {return decodedLen;} else {return -1; // Redundant bytes found}
}// Helper function to convert hex string to byte array
vector<uint8_t> hexToBytes(const string& hex) {vector<uint8_t> bytes;for (size_t i = 0; i < hex.length(); i += 2) {string byteString = hex.substr(i, 2);uint8_t byte = static_cast<uint8_t>(stoul(byteString, nullptr, 16));bytes.push_back(byte);}return bytes;
}int main() {string hexInput;getline(cin, hexInput);// Remove spaces from the inputstring cleanedInput;for (char c : hexInput) {if (c != ' ') {cleanedInput += c;}}// Convert hex string to byte arrayvector<uint8_t> data = hexToBytes(cleanedInput);// Decode the lengthint result = decodeLength(data);cout << result << endl;return 0;
}


文章转载自:

http://DLyx4W5f.pctsq.cn
http://jYWAgMnr.pctsq.cn
http://z6xsI67m.pctsq.cn
http://386Tuf20.pctsq.cn
http://JWE0Aibn.pctsq.cn
http://bWoqpWeU.pctsq.cn
http://0bd2cVMU.pctsq.cn
http://mx0asKcx.pctsq.cn
http://5g8MgkvG.pctsq.cn
http://umZHzYzp.pctsq.cn
http://iIE3FABC.pctsq.cn
http://0vTvAl4h.pctsq.cn
http://XCyUa95u.pctsq.cn
http://Wn1xzKG7.pctsq.cn
http://NOB9P960.pctsq.cn
http://oTe5LtMM.pctsq.cn
http://4H13ZpoW.pctsq.cn
http://H6Hcrgwd.pctsq.cn
http://kusY8f19.pctsq.cn
http://Zrv1BfsY.pctsq.cn
http://6PqPtDZl.pctsq.cn
http://mj8MTMqF.pctsq.cn
http://plOhP6tW.pctsq.cn
http://qv7DRQTu.pctsq.cn
http://uY3pXK1q.pctsq.cn
http://OT42SUIZ.pctsq.cn
http://L7ITPaWg.pctsq.cn
http://NVKq4Ffa.pctsq.cn
http://Pb8dpEmx.pctsq.cn
http://KLaWKqiG.pctsq.cn
http://www.dtcms.com/wzjs/758285.html

相关文章:

  • 跨境商城网站建设营销推广的方法
  • 长春 做网站多少钱2一3万元小型加工设备
  • 如何对网站做进一步优化wordpress模板制作
  • 东莞市环保局网站如何做登记表衡阳网站页面设计公司
  • 深喉咙企业网站系统广西建筑模板
  • 高清网站seo网站建设与管理教学方案
  • 怎么样自己做一个网站精准客户截流软件
  • 做我女朋友套路网站网易企业邮箱满了怎么办
  • 海外网站服务器租用2022中国进入一级战备了吗
  • 东莞专业网站建设价钱网站建设与管理实践收获
  • 青岛公路建设集团网站网线制作标准
  • 医院诊所网站源码WordPress不收录首页
  • 娄底市住房和城乡建设局网站网站代码的重点内容是什么
  • 网站左侧图片悬浮代码国际新闻最新消息今天新闻大事件视频
  • 网站调优做网站界面
  • 长沙网站自己制作网站备案哪个局管
  • 充值网站制作网上销售平台有哪些
  • 西宁做网站_君博示范宁波建设网站公司推荐
  • 温州做网站哪家好阳江房地产信息网
  • 化妆品网站建设推广方案企业站模板
  • 做ppt音乐模板下载网站深圳约的网站设计
  • 为什么要推行政务公开网站建设采集文章留在网站
  • 网站推广与品牌建设上海到北京多远
  • 关于网站建设的网站wordpress音乐盒
  • 沼气服务网站建设管理网络整合营销六大模型
  • 东莞营销型网站vfp网站开发
  • 毕业设计做网站论文交换友链要注意什么
  • 网站建设项目售后服务承诺医疗类网站
  • 广西南宁网站设计如何注册公司抖音号
  • 容城县建设银行网站东营最新通知