西南科技大学 派森 寻找不含重复字符的子串

该文章介绍了一个使用Python实现的字符串子串生成方法,通过蛮力穷举,遍历字符串并检查每个字符是否在结果列表中,构建所有可能的连续子串。程序逻辑涉及双重循环,每次发现新字符时更新子串列表,并在内层循环结束后清空临时列表。
摘要由CSDN通过智能技术生成

 Sample:

pwwkew
 

Result:

['e', 'ew', 'k', 'ke', 'kew', 'p', 'pw', 'w', 'wk', 'wke']
 

思路:蛮力穷举,最外层循环遍历该字符串,内层循环从外层循环的当前值为起始,遍历到最后。

在外层循环中,每当当前i对应的s[i]不在列表中,就将s[i]放入列表。

在内层循环中,每当当前j对应的s[j]不在列表中,就将s[j]放入列表,并且增加一个字串,该字串是当找到上一个不在列表中的s[j]时,列表中所存放的最长字串 + s[j]。

比如pwwk,按程序正常执行,lst中的值增加步骤如下(假设外层循环只执行一次):

[p],[p,w,pw],[p,w,pw,k,pwk]。

然后内层循环每结束一次,就将记录内层循环字串的列表归零。

s = input()
lst = []
lst_res = []
length = len(s)
for i in range(length):
    if s[i] not in lst:
        lst.append(s[i])
    for j in range(i + 1,length):
        if s[j] not in lst:
            lst.append(s[j])
            lst.append(lst[-2] + s[j])
    lst_res += lst
    lst.clear()
lst_res = list(set(lst_res))
lst_res.sort()
print(lst_res)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的微信机器人派森框架的代码示例,你可以根据需要进行修改和优化: ```python import itchat from threading import Thread from queue import Queue class WechatBot: def __init__(self): self.msg_queue = Queue() self.bot = itchat.new_instance() self.bot.auto_login(hotReload=True) self.bot.run(blockThread=False) self.friend_list = self.bot.get_friends() def send_msg(self, msg, to_user): self.bot.send(msg, toUserName=to_user) def handle_msg(self, msg): from_user = msg['FromUserName'] msg_type = msg['Type'] if msg_type == 'Text': content = msg['Text'] self.msg_queue.put((from_user, content)) def listen(self): @self.bot.msg_register(['Text', 'Picture', 'Recording', 'Attachment', 'Video']) def receive_msg(msg): self.handle_msg(msg) def run(self): listen_thread = Thread(target=self.listen) listen_thread.start() while True: if not self.msg_queue.empty(): from_user, content = self.msg_queue.get() # 处理消息并回复 reply = self.reply(content, from_user) self.send_msg(reply, from_user) def reply(self, msg, from_user): # 实现具体的自动回复逻辑 return "这是机器人自动回复的消息。" if __name__ == '__main__': bot = WechatBot() bot.run() ``` 以上代码实现了一个基本的微信机器人框架,它能够监听用户发送的消息并将其加入消息队列,然后在主线程中不断从消息队列中读取消息并进行处理和回复。你可以根据需要修改 `reply` 函数来实现具体的自动回复逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值