In this post, we will solve Filter Array HackerRank Solution. This problem (Filter Array) is a part of HackerRank Functional Programming series.
Task
Filter a given array of integers and output only those values that are less than a specified value X. The output integers should be in the same sequence as they were in the input. You need to write a function with the recommended method signature for the languages mentioned below. For the rest of the languages, you have to write a complete code.
Input Format
The first line contains the delimiter X.
The next B lines each contain an integer, which represents the elements of the list/array. You have to read the input to the End-Of-File.
Output Format
Print all the integers from the array that are less than the given upper limit X in value on separate lines. The sequence should be the same as it was in the original array.
Constraints
- 1 <= B <= 100
- For any element, Y in the array, -100 <= Y <= 100
- -100 <= X <= 100
Note
The purpose of this challenge is to learn how to write your own implementation of a filter function. We recommend not using the inbuilt library function.
Sample Input
3
10
9
8
2
7
5
1
3
0
Sample Output
2
1
0
Explanation
2, 1 and 0 are the list elements that are less than the X delimiter, 3. They are displayed in the same order as they were in the original list.
Recommended Method Signature
Number Of Parameters: 2
Parameters: [upper-limit(X) list]
Returns: List or Vector
For Hackers Using Clojure
This will be the outline of your function body (fill in the blank portion marked by underscores):
(fn[delim lst]___________________________)
For Hackers Using Scala
This will be the outline of your function body (fill in the blank portion marked by underscores):
def f(delim:Int,arr:List[Int]):List[Int] = __________________
For Hackers Using Haskell
This will be the outline of your function body (fill in the blank portion marked by underscores):
f n arr = _____________________
For Hackers Using other Languages
You have to read input from standard input and write output to standard output. Please follow the input/output format mentioned above.
NOTE: You only need to submit the code above after filling in the blanks appropriately. The input and output section will be handled by us. The focus is on writing the correct function.
Solution – Filter Array – HackerRank Solution
Scala
def f(delim: Int, arr: List[Int]): List[Int] = arr match { case Nil => Nil case x :: xs => if (x < delim) x :: f(delim, xs) else f(delim, xs) }
Note: This program (Filter Array) is generated by HackerRank but the solution is provided by CodingBroz. This tutorial is only for Educational and Learning purpose.