aboutsummaryrefslogtreecommitdiff
path: root/challenge-263/spadacciniweb/python/ch-1.py
blob: cec470dcac65621d768cd27b906cd15e872f9f8e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# Task 1: Target Index
# Submitted by: Mohammad Sajid Anwar
# 
# You are given an array of integers, @ints and a target element $k.
# Write a script to return the list of indices in the sorted array where the element is same as the given target element.
# 
# Example 1
# Input: @ints = (1, 5, 3, 2, 4, 2), $k = 2
# Output: (1, 2)
# 
# Sorted array: (1, 2, 2, 3, 4, 5)
# Target indices: (1, 2) as $ints[1] = 2 and $ints[2] = 2
# 
# Example 2
# Input: @ints = (1, 2, 4, 3, 5), $k = 6
# Output: ()
# 
# No element in the given array matching the given target.
# 
# Example 3
# Input: @ints = (5, 3, 2, 4, 2, 1), $k = 4
# Output: (4)
# 
# Sorted array: (1, 2, 2, 3, 4, 5)
# Target index: (4) as $ints[4] = 4

def list_of_indices(ints,k):
    ints.sort()

    indexes = list(filter(lambda i: ints[i] == k, range(len(ints))))
    print("(%s) -> (%s)" % 
             ( ",".join(map(str, ints)), 
               ",".join(map(str, indexes))
             )
    )

if __name__ == "__main__":
    ints = [1, 5, 3, 2, 4, 2]
    k = 2
    list_of_indices(ints, k)

    ints = [1, 2, 4, 3, 5]
    k = 6
    list_of_indices(ints, k)

    ints = [5, 3, 2, 4, 2, 1]
    k = 4
    list_of_indices(ints, k)