A non-empty array A consisting of N integers is given. A pair of integers (P, Q), such that 0 ≤ P < Q < N, is called a slice of array A (notice that the slice contains at least two elements). The average of a slice (P, Q) is the sum of A[P] + A[P + 1] + ... + A[Q] divided by the length of the slice. To be precise, the average equals (A[P] + A[P + 1] + ... + A[Q]) / (Q − P + 1).
For example, array A such that:
A[0] = 4 A[1] = 2 A[2] = 2 A[3] = 5 A[4] = 1 A[5] = 5 A[6] = 8contains the following example slices:
- slice (1, 2), whose average is (2 + 2) / 2 = 2;
- slice (3, 4), whose average is (5 + 1) / 2 = 3;
- slice (1, 4), whose average is (2 + 2 + 5 + 1) / 4 = 2.5.
The goal is to find the starting position of a slice whose average is minimal.
Write a function:
class Solution { public int solution(int[] A); }
that, given a non-empty array A consisting of N integers, returns the starting position of the slice with the minimal average. If there is more than one slice with a minimal average, you should return the smallest starting position of such a slice.
For example, given array A such that:
A[0] = 4 A[1] = 2 A[2] = 2 A[3] = 5 A[4] = 1 A[5] = 5 A[6] = 8the function should return 1, as explained above.
Write an efficient algorithm for the following assumptions:
- N is an integer within the range [2..100,000];
- each element of array A is an integer within the range [−10,000..10,000].
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1;
double[] minimumAverages = createMinimumAverages(A);
double min = Double.MAX_VALUE;
for (int i = 0; i < len; ++i ) {
if( minimumAverages[i] < min ) {
min = minimumAverages[i];
result = i;
}
}
return result;
}
public double[] createMinimumAverages(int[] A) {
int len = A.length;
int[] prefixSums = new int[len];
for (int i = 1; i < len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double[] minimumAverages = new double[len];
for ( int P = 0; P < len; ++P) {
double minAverage = Double.MAX_VALUE;
for (int Q = P + 1 ; Q < len; ++Q) {
int sum = prefixSums[Q + 1] - prefixSums[P];
double average = (sum)/(double) ( Q - P + 1 );
if( minAverage > average) {
minAverage = average;
}
}
minimumAverages[P] = minAverage;
}
return minimumAverages;
}
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 7 at Solution.createMinimumAverages(Solution.java:34) at Solution.solution(Solution.java:10) at wrapper.run(wrapper.java:40) at wrapper.main(wrapper.java:29)
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1;
double[] minimumAverages = createMinimumAverages(A);
double min = Double.MAX_VALUE;
for (int i = 0; i < len; ++i ) {
if( minimumAverages[i] < min ) {
min = minimumAverages[i];
result = i;
}
}
return result;
}
public double[] createMinimumAverages(int[] A) {
int len = A.length;
int[] prefixSums = new int[len];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double[] minimumAverages = new double[len];
for ( int P = 0; P < len; ++P) {
double minAverage = Double.MAX_VALUE;
for (int Q = P + 1 ; Q < len; ++Q) {
int sum = prefixSums[Q + 1] - prefixSums[P];
double average = (sum)/(double) ( Q - P + 1 );
if( minAverage > average) {
minAverage = average;
}
}
minimumAverages[P] = minAverage;
}
return minimumAverages;
}
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 7 at Solution.createMinimumAverages(Solution.java:27) at Solution.solution(Solution.java:10) at wrapper.run(wrapper.java:40) at wrapper.main(wrapper.java:29)
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1;
double[] minimumAverages = createMinimumAverages(A);
double min = Double.MAX_VALUE;
for (int i = 0; i < len; ++i ) {
if( minimumAverages[i] < min ) {
min = minimumAverages[i];
result = i;
}
}
return result;
}
public double[] createMinimumAverages(int[] A) {
int len = A.length;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double[] minimumAverages = new double[len];
for ( int P = 0; P < len; ++P) {
double minAverage = Double.MAX_VALUE;
for (int Q = P + 1 ; Q < len; ++Q) {
int sum = prefixSums[Q + 1] - prefixSums[P];
double average = (sum)/(double) ( Q - P + 1 );
if( minAverage > average) {
minAverage = average;
}
}
minimumAverages[P] = minAverage;
}
return minimumAverages;
}
}
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
//double[] minimumAverages = createMinimumAverages(A);
double min = Double.MAX_VALUE;
for (int i = 0; i < len; ++i ) {
if( minimumAverages[i] < min ) {
min = minimumAverages[i];
result = i;
}
}
return result;
}
public double[] createMinimumAverages(int[] A) {
int len = A.length;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double[] minimumAverages = new double[len];
for ( int P = 0, Q = P + 1; P < len; ++P) {
double minAverage = Double.MAX_VALUE;
int sum = prefixSums[Q + 1] - prefixSums[P];
/*for (int Q = P + 1 ; Q < len; ++Q) {
int sum = prefixSums[Q + 1] - prefixSums[P];
double average = (sum)/(double) ( Q - P + 1 );
if( minAverage > average) {
minAverage = average;
}
}*/
minimumAverages[P] = minAverage;
}
return minimumAverages;
}
}
Solution.java:18: error: cannot find symbol if( minimumAverages[i] < min ) { ^ symbol: variable minimumAverages location: class Solution Solution.java:19: error: cannot find symbol min = minimumAverages[i]; ^ symbol: variable minimumAverages location: class Solution 2 errors
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1, i = 0; Q < len; ++P ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
i = P;
}
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
i = P;
}
}
return result;
}
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8 at Solution.solution(Solution.java:19) at wrapper.run(wrapper.java:40) at wrapper.main(wrapper.java:29)
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q < len; ++P ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < len ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8 at Solution.solution(Solution.java:19) at wrapper.run(wrapper.java:40) at wrapper.main(wrapper.java:29)
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q < len; ++P ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < prefixSums.length ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8 at Solution.solution(Solution.java:19) at wrapper.run(wrapper.java:40) at wrapper.main(wrapper.java:29)
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q < prefixSums.length; ++P ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < prefixSums.length ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8 at Solution.solution(Solution.java:19) at wrapper.run(wrapper.java:40) at wrapper.main(wrapper.java:29)
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q + 1 < prefixSums.length; ++P ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < prefixSums.length ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8 at Solution.solution(Solution.java:19) at wrapper.run(wrapper.java:40) at wrapper.main(wrapper.java:29)
// you can also use imports, for example:
// import java.util.*;
// you can use System.out.println for debugging purposes, e.g.
// System.out.println("this is a debug message");
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q + 1 < prefixSums.length; ++P, ++Q ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < prefixSums.length ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q + 1 < prefixSums.length; ++P, ++Q ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < prefixSums.length ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q + 1 < prefixSums.length; ++P, ++Q ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < prefixSums.length ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
class Solution {
public int solution(int[] A) {
int len = A.length, result = len - 1, sum = 0;
int[] prefixSums = new int[len + 1];
for (int i = 1; i <= len; ++i) {
prefixSums[i] = prefixSums[i-1] + A[i-1];
}
double min = Double.MAX_VALUE, average = 0d;
for (int P = 0, Q = 1; Q + 1 < prefixSums.length; ++P, ++Q ) {
sum = prefixSums[Q + 1] - prefixSums[P];
average = (sum)/(double) 2;
if (average < min) {
min = average;
result = P;
}
if ( Q + 2 < prefixSums.length ) {
sum = prefixSums[Q + 2] - prefixSums[P];
average = (sum)/(double) 3;
if (average < min) {
min = average;
result = P;
}
}
}
return result;
}
}
The solution obtained perfect score.