Python | Alternate range slicing in list
Last Updated :
18 Apr, 2023
List slicing is quite common utility in Python, one can easily slice certain elements from a list, but sometimes, we need to perform that task in non-contiguous manner and slice alternate ranges. Let's discuss how this particular problem can be solved.
Method #1 : Using list comprehension List comprehension can be used to perform this particular task with ease as it can be used to run a loop and only filter the elements that leave a remainder more than half of target slice size multiplied by 2. By this way we can extract the sliced numbers in range alternatively.
Python3
# Python3 code to demonstrate
# alternate range slicing
# using list comprehension
# initializing list
test_list = [2, 4, 6, 8, 9, 10, 12, 16, 18, 20, 7, 30]
# printing original list
print("The original list : " + str(test_list))
# Select range size
N = 3
# using list comprehension
# alternate range slicing
res = [test_list[i] for i in range(len(test_list))
if i % (N * 2) >= N]
# print result
print("The alternate range sliced list : " + str(res))
Output : The original list : [2, 4, 6, 8, 9, 10, 12, 16, 18, 20, 7, 30]
The alternate range sliced list : [8, 9, 10, 20, 7, 30]
Time complexity: O(n), where n is the length of the list.
Auxiliary space: O(n), as a new list of size n is created to store the result of list comprehension.
Method #2 : Using enumerate() + list comprehension The list comprehension can also be combined with the enumerate function to perform this task. The advantage of using enumerate is that we can track of index along with the value and it's more efficient and has lesser run-time than the above function.
Python3
# Python3 code to demonstrate
# alternate range slicing
# using list comprehension + enumerate()
# initializing list
test_list = [2, 4, 6, 8, 9, 10, 12, 16, 18, 20, 7, 30]
# printing original list
print("The original list : " + str(test_list))
# Select range size
N = 3
# using list comprehension + enumerate()
# alternate range slicing
res = [val for i, val in enumerate(test_list)
if i % (N * 2) >= N]
# print result
print("The alternate range sliced list : " + str(res))
Output : The original list : [2, 4, 6, 8, 9, 10, 12, 16, 18, 20, 7, 30]
The alternate range sliced list : [8, 9, 10, 20, 7, 30]
Time complexity: O(n), where n is the length of the list, as the list comprehension and the enumerate() function both have linear time complexity.
Auxiliary space: O(n), as a new list of size n is created to hold the result of the list comprehension.
Method #3 : Using itertools +for loop
In this code, a list test_list is initialized with a set of values, and a variable N is defined as the range size for the alternate slicing.
Then, a loop is used to iterate over the elements of the test_list using the range() function. For each iteration, the index i is checked to see if it leaves a remainder of more than half of N when divided by N multiplied by 2. If the condition is true, the islice() function is used to slice the list and return only the element at the current index i. The result of the islice() function is then appended to the res list using the extend() method.
Finally, the res list is printed to the console.
Python3
from itertools import islice
# initializing list
test_list = [2, 4, 6, 8, 9, 10, 12, 16, 18, 20, 7, 30]
# Select range size
N = 3
# using islice()
# alternate range slicing
res = []
for i in range(len(test_list)):
if i % (N * 2) >= N:
res.extend(islice(test_list, i, i+1))
# print result
print("The alternate range sliced list:", res)
#This code is contributed by Edula Vinay Kumar Reddy
OutputThe alternate range sliced list: [8, 9, 10, 20, 7, 30]
The time complexity of this code is O(n), where n is the length of the test_list. This is because the loop iterates over the elements of the list once. The space complexity of this code is also O(n), because the res list is created and grows by one element for each iteration of the loop.
Method 4: Using filter() + enumerate() + method:
This approach uses the enumerate() function to get the index and value pairs of the test_list. The filter() function is then used to filter out the elements that do not satisfy the alternate range slicing condition. Finally, a list comprehension is used to extract the values from the filtered list.
Step-by-step approach:
- Initialize a list named test_list with some integer values.
- Print the original list using the print() function.
- Set a variable N equal to the desired range size.
- Use the enumerate() function to get the index and value pairs of the test_list.
- Use the filter() function to filter out the elements that do not satisfy the alternate range slicing condition.
- In this case, we want to keep the elements whose index modulo (N * 2) is greater than or equal to N.
- Convert the filtered values into a list using the list() function.
- Extract the values from the filtered list using a list comprehension.
- Print the resulting list using the print() function.
Below is the implementation of the above approach:
Python3
# Python3 code to demonstrate
# alternate range slicing
# using filter()
# initializing list
test_list = [2, 4, 6, 8, 9, 10, 12, 16, 18, 20, 7, 30]
# printing original list
print("The original list : " + str(test_list))
# Select range size
N = 3
# using filter()
# alternate range slicing
res = list(filter(lambda x: x[0] % (N * 2) >= N, enumerate(test_list)))
# extracting values from filtered list
res = [x[1] for x in res]
# print result
print("The alternate range sliced list : " + str(res))
OutputThe original list : [2, 4, 6, 8, 9, 10, 12, 16, 18, 20, 7, 30]
The alternate range sliced list : [8, 9, 10, 20, 7, 30]
Time complexity: O(n),
Auxiliary space: O(n), because it creates a new list to store the filtered values.
Similar Reads
Slicing range() function in Python range() allows users to generate a series of numbers within a given range. Depending on how many arguments the user is passing to the function, the user can decide where that series of numbers will begin and end as well as how big the difference will be between one number and the next.range() takes
2 min read
Python - Specific Range Addition in List Sometimes, while working with Python, we need to perform an edition in the Python list. And sometimes we need to perform this to a specific index range in it. This kind of application can have applications in many domains. Let us discuss certain ways in which this task can be performed. Method #1:
4 min read
Python | Decimal step range in list Sometimes, while working with a Python list we can have a problem in which we require to populate the list in a range of decimals. Integral ranges are easier to handle using inbuilt constructs, but having a decimal value to provide to range value doesn't work. Let's discuss a way in which this probl
4 min read
Python - Extract Elements from Ranges in List We are given a list and list containing tuples we need to extract element from ranges in tuples list. For example, n = [10, 20, 30, 40, 50, 60, 70, 80, 90] and r = [(1, 3), (5, 7)] (ranges) we need to extract elements so that output should be [[20, 30, 40], [60, 70, 80]].Using List ComprehensionList
3 min read
Python - Reverse Range in String List Given a string list, reverse each element of string list from ith to jth index. Input : test_list = ["Geeksforgeeks", "Best", "Geeks"], i, j = 1, 2 Output : ['ee', 'es', 'ee'] Explanation : Range of strings are extracted. Input : test_list = ["Geeksforgeeks"], i, j = 1, 7 Output : ['eeksfor'] Explan
3 min read