A non-empty zero-indexed array A consisting of N integers and sorted in a non-decreasing order is given. The leader of this array is the value that occurs in more than half of the elements of A.

You are given an implementation of a function:

class Solution { public int solution(int[] A); }

that, given a non-empty zero-indexed array A consisting of N integers, sorted in a non-decreasing order, returns the leader of array A. The function should return −1 if array A does not contain a leader.

For example, given array A consisting of ten elements such that:

  A[0] = 2 

  A[1] = 2

  A[2] = 2

  A[3] = 2

  A[4] = 2

  A[5] = 3

  A[6] = 4

  A[7] = 4

  A[8] = 4

  A[9] = 6

the function should return −1, because the value that occurs most frequently in the array, 2, occurs five times, and 5 is not more than half of 10.


Given array A consisting of five elements such that:


  A[0] = 1

  A[1] = 1

  A[2] = 1

  A[3] = 1

  A[4] = 50

the function should return 1.


Unfortunately, despite the fact that the function may return expected result for the example input, there is a bug in the implementation, which may produce incorrect results for other inputs. Find the bug and correct it. You should modify at most three lines of code.


Assume that:


N is an integer within the range [1..100,000];

each element of array A is an integer within the range [0..2147483647];

array A is sorted in non-decreasing order.

Complexity:


expected worst-case time complexity is O(N);

expected worst-case space complexity is O(N), beyond input storage (not counting the storage required for input arguments).

Elements of input arrays can be modified.


위의 문제는 A라는 array에 값이 들어 있는데, 2,2,3,3,4,4 이런식으로 점점 커지는 수가 들어 있는 array이다. 이중 전체 갯수에서 같은수가 절반이 넘었을때 그때의 값을 리턴해 주고, 절반이거나 절반이 되지 않으면 -1을 리턴하라는 문제이다. 풀이보단 문제 이해가 너무 어려운 문제이다.


solution

public int solution(int A[]) {


int length = A.length;

// A 어레이의 길이가 0 이거나 1이면 -1을 리턴한다. 1개이면 절대 절반이상의 갯수를 만족할수 없다.

if (length <= 1) {

return -1;

}

// 첫번째 인자를 가장최근의 인자라고 생각할때

int lastInput = A[0];

int count = 0;

int tmpValue = -1;

for (int i = 0; i < A.length; i++) {


if(lastInput == A[i]) { // 가장 마지막에 가지고 있는 값과 첫번째 값이                     //으면 카운트를 하나 올리고, 그 값을 저장하자

count++;

tmpValue = A[i];

// System.out.println("count : " + count);

}

else { // 만약 아니면 위에서 계산한 count를 계산하여 절반이상이면 

// return해주고, 아니면 count를 1로 세팅한다 (1로세팅하는 이유는 새로 하나가 추가됐기 

//때문이다

// System.out.println("count : " + count);

// System.out.println("(length/2) : " + (length/2));

if(count > (length/2)) {

return tmpValue;

}

else {

count = 1;

}

}

// 가장최근값을 가장 마지막에 저정한 값으로 넣어준다

lastInput = A[i];

System.out.println("lastInput : " + lastInput);


// 이건 마지막 놈을 체크하기 위한 루틴이다. 만약 이걸 하지 않으면 for문 //에서 else에서만 절반이 넘는지 체크를 하기 때문에 문제가 될수 있다. 예를들어 //{2,2,2,3,3,3,3,3} 이런식이면 if는 들어가지만 else에 못들어가 문제가 된다.

if(i == (length-1)) {

if(count > (length/2)) {

return tmpValue;

}

}

}

return -1;

}


'프로그래밍 > 알고리즘' 카테고리의 다른 글

BugfixingLeaderSorted  (0) 2014.12.16
CountMultiplicativePairs  (0) 2014.12.12
Min Average Two Slice by Codility  (0) 2014.12.09
by Invincible Cooler 2014. 12. 10. 17:00

문제는 아래와 같다.


A non-empty zero-indexed 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] = 8

contains 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 zero-indexed 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] = 8
the function should return 1, as explained above.
Assume that:
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].
Complexity:
expected worst-case time complexity is O(N);
expected worst-case space complexity is O(N), beyond input storage (not counting the storage required for input arguments).
Elements of input arrays can be modified.


처음에 이문제를 이렇게 오해해서 아래와 같이 풀었다.


public int solution(int A[]) {

int length = A.length;

if(length < 2) {

return 0;

}


int minIndex = 0;

double lastAverage = 0d;

   for (int i = 0; i < A.length; i++) {

   

    if(i+1 == A.length) {

    break;

    }

   

    int first = A[i];

    int second = A[i+1];

   

    if(first > second) {

    System.out.println("tmpSum : continue");

    continue;

    }


    int tmpSum = 0;

    double average = 0d;

    if(first == second) {

    average = (first+second)/2;

    System.out.println("if average : " + average);

    }

    else {

    int count = 0;

    do {

    tmpSum += first;

    first++;

    count++;

    }

    while(first <= second);

    average = (double)tmpSum/count;

   

    System.out.println("else average : " + average);

    }

    if(lastAverage == 0 || lastAverage > average) {

    lastAverage = average;

    minIndex = i;

    }

   }

   

   return minIndex;

}

어떻게 오해한것이냐면


예를 들어 int A[] = { 4, 2, 2, 5, 1, 5, 8 }; 라고하면

인접한 두개의 원소 사이에서 갯수의 합 / 카운드

다시말해서 3번째 원소 2와 4번째 원소 5는 2+3+4+5 를 해서 4개의 카운트로 나누어 평균값의 제일 작은 index로 오해를 했다. 이노무 영어가 문제다 ㅋㅋㅋ


이제 제대로 다시 풀어봐야겠다. 인접하는 두개의 원소가 아니라, 원소는 몇개가 될 수 있고, 갯수의 값의 합이구먼...


아래와 같이 수정하면 된다. 아래 내용을 잘 분석해 보면, slice가 2개 또는 3개이다. 왜 2, 3개만 적용하면되냐면, 자세한 내용은 http://codesays.com/2014/solution-to-min-avg-two-slice-by-codility/ 를 참고하면 되고, 간단하게 모든 slice는 2개 또는 3개로 나누어 진다는 것이다.

예를 들어 짝수갯수는 2로 나누어 지고, 홀수 갯수는 2로 나누어지고 마지막것이 3개라는 대충 이런개념... 아닌가? 어쨌든 결론은 2,3개의 slice이외에는 할필요가 없다는 것이다.


public int solution2(int A[]) {


int length = A.length;

if (length < 2) {

return -1;

}


if (length == 2) {

return 0;

}


int minIndex = 0;

double minAverage = 10000d;

// System.out.println("minAverage : " + minAverage);


for (int i = 0; i < length - 2; i++) {

double tmpAverage2 = (double) (A[i] + A[i + 1]) / 2;

System.out.println("2 tmpAverage : " + tmpAverage2);


if (tmpAverage2 < minAverage) {

minAverage = tmpAverage2;

minIndex = i;

}


double tmpAverage3 = (double) (A[i] + A[i + 1] + A[i + 2]) / 3;

System.out.println("3 tmpAverage : " + tmpAverage3);

if (tmpAverage3 < minAverage) {

minAverage = tmpAverage3;

minIndex = i;

}


}


return minIndex;

}


by Invincible Cooler 2014. 12. 9. 11:30

Title : Gasoline prices drop below 1,700 won per liter

휘발유 값이 리터당 1,700원 이하로 떨어졌다.

Average petrol prices in South Korea have dropped to a little below1,700 won ($1.53) per liter, according to data by Opinet, an onlineservice provider of oil prices run by the state-run Korea National OilCorp.

Opinet(온라인으로 가격을 제공하는 업체)의 데이타에 따르면, 한국에서 평균 기름값이 리더당 1,700원 이하로 떨어졌다고 한다.

Opinet said Thursday that this was the first time in four years that the nation’s average gas prices have dropped below 1,700 won. 

Opinet은 목요일에 대한민국의 평균 기름값이 1,700원 밑으로 떨어진것은 4년내 처음이라고 보도 했다.

The agency attributed the latest fall to a decline in international oil prices triggered by the Organization of the Petroleum Exporting Countries’ unwillingness to cut oil supply. The move, which is reportedly designed to squeeze the shale supply of the United States,is expected to continue keeping a lid on global oil prices for the time being.

에이전트는 최근 기름값이 떨어지는것을 OPEC 국가들이 기름 생산량을 줄이지 않겠다는 것에서 원인이 있다고 했다. 미국의 셰일 가스 공급에 대한 계속적인 압박  움직임은 당분간 국제적 기름값에 대해서 우선권을 유지하기 위해서 계속 될것이라 말했다.

대충은 맞는것 같은데... 더 부드러워질때까지 고고싱.


 

by Invincible Cooler 2014. 12. 5. 14:53