Python – Remove front K characters from each string in String List
Last Updated :
17 Apr, 2023
Sometimes, we come across an issue in which we require to delete the first K characters from each string, that we might have added by mistake and we need to extend this to the whole list. This type of utility is common in web development. Having shorthands to perform this particular job is always a plus. Let’s discuss certain ways in which this can be achieved.
Method #1 : Using list comprehension + list slicing This task can be performed by using the ability of list slicing to remove the characters and the list comprehension helps in extending that logic to whole list.
Python3
test_list = [ 'Manjeet' , 'Akash' , 'Akshat' , 'Nikhil' ]
print ( "The original list : " + str (test_list))
K = 3
res = [sub[K:] for sub in test_list]
print ( "The list after removing initial K characters : " + str (res))
|
Output :
The original list : ['Manjeet', 'Akash', 'Akshat', 'Nikhil']
The list after removing initial K characters : ['jeet', 'sh', 'hat', 'hil']
Time Complexity: O(n*n) where n is the number of elements in the list “test_list”.
Auxiliary Space: O(n) where n is the number of elements in the list “test_list”.
Method #2 : Using map() + lambda The map function can perform the task of getting the functionality executed for all the members of list and lambda function performs the task of removal of initial K elements using list comprehension.
Python3
test_list = [ 'Manjeet' , 'Akash' , 'Akshat' , 'Nikhil' ]
print ( "The original list : " + str (test_list))
K = 3
res = list ( map ( lambda i: i[K:], test_list))
print ( "The list after removing initial K characters : " + str (res))
|
Output :
The original list : ['Manjeet', 'Akash', 'Akshat', 'Nikhil']
The list after removing initial K characters : ['jeet', 'sh', 'hat', 'hil']
Time Complexity: O(n*n), where n is the number of elements in the list “test_list”.
Auxiliary Space: O(n), where n is the number of elements in the list “test_list”.
Method #3 : Using list comprehension + lstrip
Approach: Use lstrip and slicing to extract the desired number of characters from the list
Algorithm:
- We first define the original list string_list and the number of characters to remove from the front of each string K.
- We then use a list comprehension to create a new list new_list, where each string is modified by calling the str.lstrip() method with the substring s[:K] as its argument.
- The str.lstrip() method removes any characters from the beginning of the string that match the specified substring. 4. We print the new list to verify that the modification was successful.
Python3
string_list = [ 'Manjeet' , 'Akash' , 'Akshat' , 'Nikhil' ]
K = 3
new_list = [s.lstrip(s[:K]) for s in string_list]
print (new_list)
|
Output
['jeet', 'sh', 'hat', 'hil']
Time complexity: O(n*k)
Auxiliary Space: O(n)
Method #6: Using a for loop
Algorithm:
- Initialize an empty list “res”.
- Loop through the elements of the input list “test_list”.
- For each element, extract the substring after the first K characters and append it to the “res” list.
- Return the “res” list.
Python3
test_list = [ 'Manjeet' , 'Akash' , 'Akshat' , 'Nikhil' ]
print ( "The original list : " + str (test_list))
K = 3
res = []
for sub in test_list:
res.append(sub[K:])
print ( "The list after removing initial K characters : " + str (res))
|
Output
The original list : ['Manjeet', 'Akash', 'Akshat', 'Nikhil']
The list after removing initial K characters : ['jeet', 'sh', 'hat', 'hil']
Time complexity: O(nm), where n is the length of the input list “test_list” and m is the maximum length of any string in the list.
Auxiliary space: O(nm), as we are creating a new list “res” of the same size as “test_list”, and each element of “res” is a substring of the corresponding element of “test_list”.
Method#7: Using the Recursive method:
Algorithm:
- In this implementation, remove_front_k takes a list lst and an integer k as input. It returns a new list where each string in lst has its first k characters removed. If k is negative, it returns the original list without modifying it.
- The implementation uses recursion to process the list as the following:
- The base case is when lst is empty, in which case the function returns an empty list.
- Otherwise, the function removes the first k characters from the first string in lst using slicing notation [k:], then calls itself recursively on the rest of the list lst[1:].
- The result of the recursive call is concatenated with the modified first string using a list comprehension [s[k:] for s in lst].
Python3
def remove_front_k(lst, k):
if not lst:
return []
return [s[k:] for s in lst] if k > = 0 else lst
test_list = [ 'Manjeet' , 'Akash' , 'Akshat' , 'Nikhil' ]
K = 3
result = remove_front_k(test_list, K)
print ( "The original list : " + str (test_list))
print ( "The list after removing initial K characters : " + str (result))
|
Output
The original list : ['Manjeet', 'Akash', 'Akshat', 'Nikhil']
The list after removing initial K characters : ['jeet', 'sh', 'hat', 'hil']
Time Complexity: O(n * m), where n is the length of the list and m is the maximum length of a string in the list. This is because the function needs to slice the first k characters from each string in the list, which takes O(m) time, and it needs to do this for each string in the list, which takes O(n) time in the worst case.
Space Complexity: O(n * m), because the recursive function calls itself n times, and each call creates a new list with n-1 strings, each of which may have a maximum length of m. However, note that this is the worst-case space complexity because it assumes that each call to the function creates a new list. In practice, the Python interpreter may optimize the function calls and reuse the same list in memory, reducing the actual space usage.
Please Login to comment...