鱼C论坛

 找回密码
 立即注册
查看: 1183|回复: 7

[已解决]请教一个字符串的问题

[复制链接]
发表于 2020-6-15 19:31:35 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 llsl 于 2020-6-15 20:07 编辑

事先给好一些字符串的列表,然后把一个字符串分成列表中的字符串,并且顺序和s是相同的
比如一个字符串s和给定列表l
  1. l = ['A', 'B', 'C', 'D', 'id', 'num', 'func']
  2. s = 'ABCCidnum'
复制代码

把s分成
  1. ['A', 'B', 'C', 'C', 'id', 'num']
复制代码

请问下该如何操作

看了两位的回答后,突然想到一种比较笨的方法:
  1. s = 'ABCCidnum'
  2. l = ['A', 'B', 'C', 'D', 'id', 'num', 'func']
  3. result = []
  4. max_len = max([len(i) for i in l])
  5. while True:
  6.     if s == '':
  7.         break
  8.     for i in range(1, max_len + 1):
  9.         if s[:i] in l:
  10.             result.append(s[:i])
  11.             s = s[i:]
复制代码
最佳答案
2020-6-15 20:56:30
llsl 发表于 2020-6-15 19:46
修改了,有没有不改变顺序的方法,就有点像词法分析,把字符串变成词法记号


唉  我太笨了想半天才想了个这样的方法...看看行不行的?


  1. l = ['A', 'B', 'C', 'D', 'id', 'num', 'func']
  2. s ='ABCCidnum'

  3. result = []
  4. record = []
  5. for i in l:
  6.     if i in s:
  7.         count = s.index(i)
  8.         record.append((count,len(i)))
  9.         while True:
  10.             count = s.find(i,count+1,)
  11.             if count != -1:
  12.                 record.append((count,len(i)))
  13.             else:
  14.                 break

  15. for i in record:
  16.     result.append(s[i[0]:i[0]+i[1]])
  17. print(result)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-6-15 19:33:32 | 显示全部楼层
  1. l = ['A', 'B', 'C', 'D', 'id', 'num', 'func']
  2. temp = l[:]
  3. s = 'ABCidnum'
  4. for each in temp:
  5.     if each not in s:
  6.         l.remove(each)
  7. print(l)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-6-15 19:39:10 | 显示全部楼层

这样这能找到第一个啊,如果s中有两个一样的字符串的话就找不出来了呀,
比如
  1. s = 'ABCCidnum'
复制代码

第二个C就找不出来了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-15 19:41:16 | 显示全部楼层


你这个不是集合吗?怎么给的都是列表呢?

  1. l = {'A', 'B', 'C', 'D', 'id', 'num', 'func'}
  2. s = 'ABCidnum'
  3. temp = set()
  4. for i in l:
  5.     if i in s:
  6.         temp.add(i)
  7. print(temp)
复制代码


集合元素唯一性,不会有重复的元素
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-6-15 19:46:12 | 显示全部楼层
本帖最后由 llsl 于 2020-6-15 19:47 编辑
Twilight6 发表于 2020-6-15 19:41
你这个不是集合吗?怎么给的都是列表呢?


修改了,有没有不改变顺序的方法,就有点像词法分析,把字符串变成词法记号
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-15 20:56:30 | 显示全部楼层    本楼为最佳答案   
llsl 发表于 2020-6-15 19:46
修改了,有没有不改变顺序的方法,就有点像词法分析,把字符串变成词法记号


唉  我太笨了想半天才想了个这样的方法...看看行不行的?


  1. l = ['A', 'B', 'C', 'D', 'id', 'num', 'func']
  2. s ='ABCCidnum'

  3. result = []
  4. record = []
  5. for i in l:
  6.     if i in s:
  7.         count = s.index(i)
  8.         record.append((count,len(i)))
  9.         while True:
  10.             count = s.find(i,count+1,)
  11.             if count != -1:
  12.                 record.append((count,len(i)))
  13.             else:
  14.                 break

  15. for i in record:
  16.     result.append(s[i[0]:i[0]+i[1]])
  17. print(result)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-6-15 21:11:39 | 显示全部楼层
Twilight6 发表于 2020-6-15 20:56
唉  我太笨了想半天才想了个这样的方法...看看行不行的?

我也想到了一个笨办法,写在问题里了,多谢了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-15 21:16:47 | 显示全部楼层
llsl 发表于 2020-6-15 21:11
我也想到了一个笨办法,写在问题里了,多谢了

那就给个最佳吧,虽然没你写的好哈哈
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-21 21:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表