字符串解码

567 篇文章

已下架不支持订阅

153 篇文章

已下架不支持订阅

题目来源

394. 字符串解码 - 力扣(LeetCode)

本题可以基于栈结构解题。

初始时,我们定义一个栈stack,两个临时变量num和sb,其中:

本题编码的字符串:k[encoded_string]

  • num 用于记录 k,初始化num为空串
  • sb 用于记录 encoded_string,初始化sb为空串

然后遍历输入的编码字符串的每一个字符c:

  • 如果 c 是数字,则记录入num串

比如遍历 "3[a]2[bc]" 的第0个索引的字符'3',则拼接num串后面

已下架不支持订阅

在不同的编程语言和场景下,对二进制字符串进行解码有不同的方法。以下以 Python 为例,介绍几种常见的二进制字符串解码情况: ### 二进制字符串转普通字符串 如果二进制字符串代表的是 ASCII 编码的字符,可以使用 Python 的 `int` 函数将二进制字符串转换为整数,再使用 `chr` 函数将整数转换为字符。示例代码如下: ```python binary_str = "01100001" # 对应的 ASCII 字符是 'a' decimal_num = int(binary_str, 2) char = chr(decimal_num) print(char) ``` ### 对 base64 编码后的二进制字符串进行解码Python 中,对于 base64 编码之后的二进制字符串进行解码,可使用 `base64` 模块的 `b64decode` 函数。如在服务端接收到 iOS app 端使用 Swift 将 PDF 文件进行 base64 编码后的数据,就可以使用此方法解码并写回文件。示例代码如下: ```python import base64 # 假设接收到的 base64 编码的二进制字符串 base64_encoded_str = "..." decoded_data = base64.b64decode(base64_encoded_str) # 将解码后的数据写回文件 with open('output.pdf', 'wb') as f: f.write(decoded_data) ``` ### BCD 码二进制转十六进制字符串Java 中,可将 BCD 码的二进制数据转换为十六进制字符串。示例代码如下: ```java public class Bcd2HexStr { /** * bcd码转换成16进制的字符串 * * @eg1:1234的bcd:[18,52] * @eg2:123a的bcd:[18,58] * * @param bytes * @return */ public static String convert(byte[] bytes) { char stra[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' }; StringBuffer temp = new StringBuffer(bytes.length * 2); for (int i = 0; i < bytes.length; i++) { temp.append(stra[(bytes[i] & 0xf0) >> 4]); temp.append(stra[bytes[i] & 0x0f]); } return temp.toString(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程序员阿甘

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

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

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

打赏作者

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

抵扣说明:

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

余额充值