Skip to content

Znajdowanie lidera w zbiorze

🔗 Opis problemu

Implementation

fun countOccurrences(element: Int, array: List<Int>): Int {
  var count = 0

  for (el in array) {
    if (el == element) {
      count += 1
    }
  }

  return count
}

fun findMajority(array: List<Int>): Int {
  var counter = 0
  var currentCandidate = 0

  for (el in array) {
    if(counter == 0) {
      currentCandidate = el
      counter = 1
    } else if (el == currentCandidate) {
      counter += 1
    } else {
      counter -= 1
    }
  }

  if (countOccurrences(currentCandidate, array) >= array.count() / 2) {
    return currentCandidate
  } else {
    return -1
  }
}

fun main() {
  val array = listOf(1, 2, 5, 5, 7, 5, 5, 10, 5, 5)

  val majority = findMajority(array)

  if (majority == -1) {
    println("Nie ma lidera")
  } else {
    println("Lider to $majority")
  }
}

Znajdowanie lidera w zbiorze

Description implementacji

TODO