蓝桥杯每日一练——字符串的输入输出处理 python

题目描述
字符串的输入输出处理。
输入
第一行是一个正整数N,最大为100。之后是多行字符串(行数大于N), 每一行字符串可能含有空格,字符数不超过1000。
输出
先将输入中的前N行字符串(可能含有空格)原样输出,再将余下的字符串(不含有空格)以空格或回车分割依次按行输出。每行输出之间输出一个空行。
样例输入
2
www.dotcpp.com DOTCPP
A C M
D O T CPP
样例输出
www.dotcpp.com DOTCPP

A C M

D

O

T

CPP

n = int(input())
while True:
    string = input()
    if n > 0:
        print(string,end='\n\n')
    else:
        for i in string.split(): # 可以直接这么写我也是没想到
            print(i,end='\n\n')
    n -= 1
### 关于Python字符串对比的蓝桥杯竞赛示例 对于涉及字符串操作的比赛题目,尤其是像蓝桥杯这样的编程竞赛,理解如何高效处理字符串至关重要。下面展示了一个典型的例子——通过一次交换获得按字典序排列的最小字符串。 #### 题目描述 给定一个字符串 `s` ,允许执行至多一次字符交换操作来获取可能存在的最小字典顺序字符串。如果无法通过任何单次交换使字符串变小,则应返回原始字符串不变[^1]。 #### 解题思路 要解决这个问题的关键在于找到可以通过交换得到更小序列的位置组合。具体来说: - 找到最后一个满足条件的位置 i (0 ≤ i < n),使得存在 j > i 并且 s[j] < s[i] - 如果找到了上述位置,在所有符合条件的 j 中选取最大的那个作为目标索引 t - 将这两个位置上的字母互换即可形成新的最优解;如果没有发现合适的位置则保持原样输出 下面是实现该算法的具体 Python 代码片段: ```python def min_string_swap(s): char_list = list(s) # 寻找最后一个可优化点 index_to_swap = -1 for i in range(len(char_list)-2, -1, -1): if char_list[i] > char_list[-1]: continue for j in reversed(range(i+1, len(char_list))): if char_list[j] < char_list[i]: index_to_swap = j break if index_to_swap != -1: temp = char_list[index_to_swap] char_list[index_to_swap] = char_list[i] char_list[i] = temp return ''.join(char_list) return s ``` 此函数接收输入参数 `s` 表示待处理字符串,并尝试应用上述逻辑对其进行转换。最终它会返回经过调整后的最小子串或者是未改变过的初始状态下的子串之一取决于是否存在有效的改进方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值