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
Python - Concatenate Ranged Values in String list
Given list of strings, perform concatenation of ranged values from the Strings list. Input : test_list = ["abGFGcs", "cdforef", "asalloi"], i, j = 3, 5 Output : FGorll Explanation : All string sliced, FG, or and ll from all three strings and concatenated. Input : test_list = ["aGFGcs", "cforef", "aa
5 min read
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 - Ranged Maximum Element in String List
Sometimes, while working with Python data, we can have a problem in which we have data in form of String List and we require to find the maximum element in that data, but that also in a certain range of indices. This is quite peculiar problem but can have application in data domains. Let's discuss c
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 | Alternate element summation in list
The problem of getting summation of a list is quite generic and we might some day face the issue of getting the summation of alternate elements and get the list of 2 elements containing summation of alternate elements. Let's discuss certain ways in which this can be performed. Method #1 : Using list
5 min read
Python | Convert String ranges to list
Sometimes, while working in applications we can have a problem in which we are given a naive string that provides ranges separated by a hyphen and other numbers separated by commas. This problem can occur across many places. Let's discuss certain ways in which this problem can be solved. Method #1:
6 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 | Merge Range Characters in List
Sometimes, we require to merge some of the elements as single element in the list. This is usually with the cases with character to string conversion. This type of task is usually required in development domain to merge the names into one element. Letâs discuss certain ways in which this can be perf
6 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