题解 | 字符串分隔
字符串分隔
https://www.nowcoder.com/practice/d9162298cb5a437aad722fccccaae8a7
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
【代码能力描述】
本程序是一个字符串格式化输出程序,主要功能是:
1. 从标准输入读取字符串(长度1-100)
2. 按每8个字符一行输出
3. 最后一如果不足8个,则末尾补充 '0' 直到满8位
【核心技能点】
- sys.stdin.read() - 读取标准输入所有内容
- str.strip() - 去除首尾空白
- list() - 字符串转字符列表
- 列表索引操作 - 按位置写入字符
- str.join() - 列表拼接成字符串
【题目要求】
- 输入:长度1-100的字符串(小写字母+数字)
- 输出:每行8个字符,最后一行不足则补 '0'
"""
# ========== 导入标准库 ==========
import sys # 导入 sys 模块,用于访问标准输入输出
# ========== 定义主函数 ==========
def solve():
"""
按每8个字符一行输出字符串,不足则补 '0'
【处理流程】
1. 读取输入字符串
2. 验证长度合法性
3. 按8个一组处理
4. 最后不足8个时补充 '0'
"""
# 第1步:读取所有输入数据
# sys.stdin.read() 一次性读取所有输入
# .strip() 去除首尾空白(包括换行符)
data = sys.stdin.read().strip()
# 第2步:验证输入长度是否合法
# range(1, 101) 生成 1-100 的整数序列
# 题目要求长度在 1-100 之间
if len(data) not in range(1, 101):
return # 不合法则直接返回,不处理
# 第3步:将字符串转换为字符列表
# list() 会将字符串的每个字符作为一个元素
# 例如: "abc" -> ['a', 'b', 'c']
split_data = list(data)
# ========== 核心处理逻辑 ==========
# 第4步:初始化输出缓冲区
# 创建一个包含8个"0"字符串的列表,作为初始状态
# 后面会逐个替换为实际字符
pri_out = ["0", "0", "0", "0", "0", "0", "0", "0"]
# 第5步:初始化索引计数器
# j 表示当前写入的位置(0-7)
# 【关键】这个变量必须在 for 循环外面定义!
j = 0
# 第6步:遍历每个字符,逐个写入缓冲区
for i in split_data:
# 将当前字符写入对应位置
pri_out[j] = i
# 移动到下一个位置
j += 1
# 第7步:判断是否已写满8个字符
if j == 8:
# 缓冲区已满,输出这一行
# "".join(pri_out) 将列表中的所有字符串拼接在一起
print("".join(pri_out))
# 重置缓冲区,继续处理下一组
pri_out = ["0"] * 8
# 索引归零,重新开始计数
j = 0
# ========== 处理最后不满8个的情况 ==========
# 第8步:如果最后还有剩余字符(不足8个)
# j > 0 表示已经写了至少1个字符但没写满8个
if j > 0:
# 输出最后一行
# 此时 pri_out 中:已写入的字符在前面,后面自动是 "0" 补齐
print("".join(pri_out))
# ========== 程序入口 ==========
# 当直接运行此脚本时(而非被导入时),执行 solve() 函数
if __name__ == "__main__":
solve()
