Tuesday, August 1, 2017

Plus Minus - Problem HackerRank

Problem Statement

Given an array of integers, calculate which fraction of its elements are positive, which fraction of its elements are negative, and which fraction of its elements are zeroes, respectively. Print the decimal value of each fraction on a new line.
Note: This challenge introduces precision problems. The test cases are scaled to six decimal places, though answers with absolute error of up to  are acceptable.
Input Format
The first line contains an integer, , denoting the size of the array. 
The second line contains  space-separated integers describing an array of numbers .
Output Format
You must print the following  lines:
  1. A decimal representing of the fraction of positive numbers in the array compared to its size.
  2. A decimal representing of the fraction of negative numbers in the array compared to its size.
  3. A decimal representing of the fraction of zeroes in the array compared to its size.
Sample Input
6
-4 3 -9 0 4 1         
Sample Output
0.500000
0.333333
0.166667
Explanation
There are  positive numbers,  negative numbers, and  zero in the array. 
The respective fractions of positive numbers, negative numbers and zeroes are  and , respectively.

Problem Solution using python 2:

from __future__ import division
n = input()
arr = map(int,raw_input().split()[:n])
positivevalue = format(len([x for x in arr if x >0])/n , '.6f')
negativevalue = format(len([x for x in arr if x <0])/n , '.6f')
zerovalue = format(len([x for x in arr if x == 0])/n , '.6f')
print positivevalue
print negativevalue
print zerovalue

No comments:

Post a Comment