当前位置: 首页 > 面试经验 >

【华为OD机试2023】去除多余空格(Python)

优质
小牛编辑
160浏览
2023-03-28

【华为OD机试2023】去除多余空格(Python)

题目描述:

去除文本多余空格,但不去除配对单引号之间的多余空格。给出关键词的起始和结束下标,去除多余空格后刷新关键词的起始和结束下标。

条件约束:

1,不考虑关键词起始和结束位置为空格的场景;

2,单词的的开始和结束下标保证涵盖一个完整的单词,即一个坐标对开始和结束下标之间不会有多余的空格;

3,如果有单引号,则用例保证单引号成对出现;

4,关键词可能会重复;

5,文本字符长度length取值范围:[0, 100000];

输入描述:

输入为两行字符串:

第一行:待去除多余空格的文本,用例保证如果有单引号,则单引号成对出现,且单引号可能有多对。

第二行:关键词的开始和结束坐标,关键词间以逗号区分,关键词内的开始和结束位置以单空格区分。

例如:

Life is painting a  picture, not doing 'a  sum'. 8 15,20 26,43 45

关键单词为:painting picture sum

输出描述:

输出为两行字符串:

第一行:去除多余空格后的文本

第二行:去除多余空格后的关键词的坐标开始和结束位置,为数组方式输出。

例如:

Life is painting a picture, not doing 'a  sum'.

[8, 15][19, 25][42, 44]

示例1

输入:

Life is painting a  picture, not doing 'a  sum'.

8 15,20 26,43 45

输出:

Life is painting a picture, not doing 'a  sum'.

[8, 15][19, 25][42, 44]

说明:

a和picture中间多余的空格进行删除

示例2

输入:

Life is painting a picture, not doing 'a  sum'.

8 15,19 25,42 44

输出:

Life is painting a picture, not doing 'a  sum'.

[8, 15][19, 25][42, 44]

说明:

a和sum之间有多余的空格,但是因为有成对单引号,不去除多余空格

解题思路:

用栈stack辅助存储成对单引号,再用列表space存储多余空格的下标。

遍历整个字符串,当栈为空,那说明在此之前没有单引号,如果当前字符为单引号,把单引号压入栈,如果当前字符是空格,且前一个字符也是空格,则把前一个字符的下标压入space

当栈非空,说明此前遍历的字符正在引号内,这种情况不需要去除多余空格,仅当当前字符为单引号时,弹出stack内的单引号。


st=input()
pre_keyword=input().split(',')
key_word=[list(map(int,pre_keyword[i].split())) for i in range(len(pre_keyword))]
stack=[]
space=[]
pre_value=' '
for i,value in enumerate(st):
if not stack:
if value=="'":
stack.append("'")
else:
if pre_value==' ' and value==' ':
space.append(i-1)
else:
if value=="'":
stack.pop()
pre_value=value
for i in range(len(key_word)):
for j in range(2):
count=0
for k in space:
if key_word[i][j]>=k:
count+=1
key_word[i][j]-=count
lst=list(st)
for item in space:
lst.pop(item)
print(''.join(lst))
print(key_word)

 类似资料: