mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
add alternative_string_arrange method (#4595)
* add alternative_string_arrange method * fix issue * fix one more issue * changed the variable name li to output_list
This commit is contained in:
parent
5957eabd3e
commit
f432bc76a6
31
strings/alternative_string_arrange.py
Normal file
31
strings/alternative_string_arrange.py
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
def alternative_string_arrange(first_str: str, second_str: str) -> str:
|
||||||
|
"""
|
||||||
|
Return the alternative arrangements of the two strings.
|
||||||
|
:param first_str:
|
||||||
|
:param second_str:
|
||||||
|
:return: String
|
||||||
|
>>> alternative_string_arrange("ABCD", "XY")
|
||||||
|
'AXBYCD'
|
||||||
|
>>> alternative_string_arrange("XY", "ABCD")
|
||||||
|
'XAYBCD'
|
||||||
|
>>> alternative_string_arrange("AB", "XYZ")
|
||||||
|
'AXBYZ'
|
||||||
|
>>> alternative_string_arrange("ABC", "")
|
||||||
|
'ABC'
|
||||||
|
"""
|
||||||
|
first_str_length: int = len(first_str)
|
||||||
|
second_str_length: int = len(second_str)
|
||||||
|
abs_length: int = (
|
||||||
|
first_str_length if first_str_length > second_str_length else second_str_length
|
||||||
|
)
|
||||||
|
output_list: list = []
|
||||||
|
for char_count in range(abs_length):
|
||||||
|
if char_count < first_str_length:
|
||||||
|
output_list.append(first_str[char_count])
|
||||||
|
if char_count < second_str_length:
|
||||||
|
output_list.append(second_str[char_count])
|
||||||
|
return "".join(output_list)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
print(alternative_string_arrange("AB", "XYZ"), end=" ")
|
Loading…
Reference in New Issue
Block a user