Compute the Indices of the Target Element in Array/List using Py
- Time:2020-09-13 14:33:25
- Class:Weblog
- Read:31
Given an array (or list), and a target element, find all the indices that the element appears in it. For example,
Array: [1, 2, 3, 4, 5, 5, 6, 7, 8], and find the element 5, which appears in index 4 and 5, thus return [4, 5].
This is a trivial question and most programmers know how to do this using a for loop. For example,
In Python:
1 2 3 4 5 6 | def getIndices(data, element): x = [] for i in range(len(data)): if data[i] == element: x.append(i) return x |
def getIndices(data, element): x = [] for i in range(len(data)): if data[i] == element: x.append(i) return x
Or similarly in Javascript:
1 2 3 4 5 6 7 8 9 | function getIndices(data, element) { let x = []; for (let i = 0; i < data.length; i += 1) { if (data[i] === element) { x.push(i); } } return x; } |
function getIndices(data, element) { let x = []; for (let i = 0; i < data.length; i += 1) { if (data[i] === element) { x.push(i); } } return x; }
However, as a spirit of avoiding loops as much as you can, we can simplify the implementation. In Python, we can use the enumerate and the list comprehension which gives us the following short and concise solution to return the list of the indices for a target element in the array.
1 2 | def getIndices(data, element): return [x for x, y in enumerate(data) if y == element] |
def getIndices(data, element): return [x for x, y in enumerate(data) if y == element]
In Javascript, we could similarly implement a enumerate function, alternatively, we can chain map and filter function.
1 2 3 4 5 6 7 8 | function getIndices(data, element) { let i = -1; return data.map(x => { i ++; // incrementing the index // return index for target element return x == element ? i : false; }).filter(x => typeof x !== 'boolean'); } |
function getIndices(data, element) { let i = -1; return data.map(x => { i ++; // incrementing the index // return index for target element return x == element ? i : false; }).filter(x => typeof x !== 'boolean'); }
The map function maps those target elements with their indices, and others similar set to false – which will be filtered out via filter.
–EOF (The Ultimate Computing & Technology Blog) —
Recommend:Planning To Update Your Website For 2020? Read This.
Learn to Stay Cool in Online Casinos and Control Emotions
Bash Function to Check Palindrome Strings
Algorithm to Find Duplicate Files in System using Hash Map
C++ Coding Reference: Copy N values by using std::fill_n()
C++ Advanced Topics: 10 Questions
C++ Coding Reference: Filling a Range with a Value using std::fi
How to Get List of IP addresses in BASH using hostname and tr co
C++ Coding Reference: iota() – Setting Incrementing Values
Javascript: From Promises to Async/Await
- Comment list
-
- Comment add