python 【问题描述】 对字符串由数字和 “*”星型字符两种字符无序构成的stra,,现在想把所有的星型字符挪到数组的左边,数字字符全部放到右边,数字字符之间的相互顺序不变。补充程序中所缺代码,完成上述功能。 【输入形式】 输入一个有数字和星号构成的字符串 【输出形式】 换位后的字符串 【样例输入】 12*23**567 【样例输出】 ***1223567 def main(): stra = input() lista= list(stra) print( ) def replace_stars( str_list): # 将所有*号移动到数组的左侧 j = len(str_list) - 1 for i in range(len(str_list) - 1, -1, -1): if str_list[i] != '*': j -= 1 return str_list main()
时间: 2024-02-14 15:12:14 浏览: 204
在 `replace_stars` 函数中,可以使用双指针的方法,将星号字符移到左侧,将数字移到右侧。具体实现见下:
```python
def replace_stars(str_list):
# 将所有*号移动到数组的左侧
left, right = 0, len(str_list) - 1
while left < right:
# 将左侧第一个数字移到右侧
while left < right and str_list[left] == '*':
left += 1
# 将右侧第一个星号移到左侧
while left < right and str_list[right] != '*':
right -= 1
# 交换左侧的星号和右侧的数字
str_list[left], str_list[right] = str_list[right], str_list[left]
return str_list
```
然后在 `main` 函数中调用 `replace_stars` 函数,并将返回的字符串列表转换成字符串输出即可:
```python
def main():
stra = input()
lista = list(stra)
lista = replace_stars(lista)
print(''.join(lista))
```
相关问题
Python 对字符串由数字和 “*”星型字符两种字符无序构成的stra,,现在想把所有的星型字符挪到数组的左边,数字字符全部放到右边,数字字符之间的相互顺序不变。补充程序中所缺代码,完成上述功能。 【输入形式】 输入一个有数字和星号构成的字符串 【输出形式】 换位后的字符串 【样例输入】 12*23**567 【样例输出】 ***1223567
以下是代码实现:
```python
s = input() # 输入字符串
lst = list(s) # 将字符串转换为列表
left, right = 0, len(lst) - 1 # 定义左右指针
while left < right:
if lst[left] == '*': # 如果左指针指向的是星号
left += 1 # 左指针右移
elif lst[right] != '*': # 如果右指针指向的不是星号
right -= 1 # 右指针左移
else: # 如果左指针指向的是数字,右指针指向的是星号
lst[left], lst[right] = lst[right], lst[left] # 交换左右指针指向的字符
left += 1 # 左指针右移
right -= 1 # 右指针左移
print(''.join(lst)) # 将列表转换为字符串并输出
```
样例输入:
```
12*23**567
```
样例输出:
```
***1223567
```
对字符串由数字和 “*”星型字符两种字符无序构成的stra,,现在想把所有的星型字符挪到数组的左边,数字字符全部放到右边,数字字符之间的相互顺序不变。补充程序中所缺代码,完成上述功能。
可以使用双指针法,一个指针从左往右扫描,另一个指针从右往左扫描。当左指针指向星型字符,右指针指向数字字符时,交换两个字符的位置,直到左右指针相遇为止。
以下是代码实现:
```python
def move_stra(stra):
left = 0
right = len(stra) - 1
while left < right:
if stra[left] == '*':
left += 1
elif stra[right].isdigit():
right -= 1
else:
# 交换左右指针所指向的字符
stra[left], stra[right] = stra[right], stra[left]
left += 1
right -= 1
return stra
```
测试:
```python
stra = ['1', '2', '*', '3', '*', '4', '*', '5']
print(move_stra(stra)) # ['*', '*', '*', '1', '2', '3', '4', '5']
```
阅读全文