问题描述
考虑两个字符串 s1 和 s2,您必须编写一个静态函数,该函数以 s1 和 s2 字符串作为参数,并从第一个字符串中删除出现在第二个字符串中的字符。例如,如果第一个字符串“India is great”,第二个字符串是“in”,那么输出应该是“da s great”。
输入格式
第一行应该包含字符串 s1。第二行应包含字符串 s2。
Constraints
1<=N<=1000
Output Format
Output string
Sample Input 0
India is great
in
Sample Output 0
da s great
Sample Input 1
Hello all how are you
are
Sample Output 1
Hllo ll how you
我的代码
lst = [i for i in input()]
check = [i for i in input()]
for i in check:
for j in lst:
if i == j or i.upper() == j:
lst.remove(j)
for i in lst:
print(i,end='')
我的输出
da s great
Hllo ll how you
解决方法
看起来您只需要将字符串中包含两个空格的部分替换为一个空格即可。删除整个单词时会出现两个空格的情况。
import re
lst = input()
check = [str.lower(c) for c in input()]
upper_check = [str.upper(c) for c in check]
for i in range(len(check)):
lst = lst.replace(check[i],'')
lst = lst.replace(upper_check[i],'')
lst = re.sub(r"\s+",' ',lst)
print(lst.strip())
,
你永远不应该修改你正在循环的列表。 相反,您可以生成一个不包含禁用字符的新字符串。 此外,为了在算法上更高效,您可以将所有禁用字符存储在一个集合中。
input_s = input() # No need to loop over the lists here.
forbidden_chars = {c.lower() for c in input()}
new_s = ''.join([char in input_s if char.lower() not in forbidden_chars])
print(new_s)
,
过滤列表推导式中的字符并使用 join 将结果重新组合在一起:
def remove(s1,s2):
return "".join(c for c in s1 if c.lower() not in s2.lower())
print(remove("India is great","in"))
# da s great
您还可以通过构建要删除的大写和小写字母列表来使用翻译:
def remove(s1,s2):
exclude = str.maketrans("","",s2.lower()+s2.upper())
return s1.translate(exclude)
删除连续的空格可以通过拆分和重建字符串来完成:
return " ".join(s1.translate(exclude).split())