Compute the Indices of the Target Element in Array/List using Py
- 时间:2020-09-13 14:33:25
- 分类:网络文摘
- 阅读:152 次
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 xOr 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) —
推荐阅读:国人消费崇洋媚外导致洋奶粉的傲慢 暴利诱惑导致贴牌洋奶粉占八成市场 食药监部门曝光12个保健食品违法广告 薏米红豆汤 如何烹饪果蔬食物营养损失更少 食品安全监管常态化胜过千句狠话 夏季凉拌西红柿时用蜂蜜更滋补 对大豆制品存在的一些认识误区 食品安全:广州镉超标大米事件追踪 味精的食用安全性及合适用量问题
- 评论列表
-
- 添加评论