Skip to content

Latest commit

 

History

History
65 lines (41 loc) · 3.38 KB

README.md

File metadata and controls

65 lines (41 loc) · 3.38 KB

hare-clark-cpp

Hare-Clark is an electoral system used in Tasmania and the Australian Capital Territory. To read more on how the preferential votes are distributed, please refer to the Wikipedia article, which is what this implementation is mostly based off of.

Additional sources:

Usage

This is a single-header library. To use this, simply download the src/hare-clark.hpp file into your project and #include "hare-clark.hpp".

However, it is recommended that you add this repository as a submodule using git submodule add https://github.com/tinnamchoi/hare-clark-cpp to make updating the library easier. Read more on Git submodules here.

Functions

HareClark(int number_of_vacancies = 1)

Construct a new Hare Clark object

Parameters Description
number_of_vacancies Number of vacancies, defaulted to 1

void add_candidates(std::vector<std::string> candidates)

Add to the list of candidates

Parameters Description
candidates List of candidates to be added

void add_ballots(std::vector<std::vector<int>> ballots)

Add to the list of ballots

Parameters Description
ballots List of ballots to be added

Each ballot is a list of integers, where each integer represents the index of the candidate in the list of candidates.

e.g. with a candidate list of {"A", "B", "C"}, a ballot of {2, 0, 1} would represent a ballot with "C" as the first preference, "A" as the second preference, and "B" as the third preference.

std::vector<std::string> run()

Run the Hare-Clark process

Returns Description
elected_candidates List of elected candidates

Examples

For a practical example of the library being applied, see example/README.md

Complexity analysis

  • Let $v$, $b$, and $c$ be the number of vacancies, ballots, and candidates respectively.
  • HareClark() uses $O(1)$ time as it only has a single variable assignment
  • add_candidates() uses $O(c)$ time as it has to insert each of the $c$ candidates to the private variable
  • add_ballots() uses $O(bc)$ time as each ballot must have exactly $c$ values, and each of the $b$ ballots must be inserted to the private variable
  • run() It takes $O(bc)$ time and auxilliary space for preprocessing and creating a copy of the private variables. It will then take $O(bb+bc)$ time to calculate the results. $O(bb)$ since there can be a maximum of $b$ loops which each go through each of the $b$ ballots, and an additional $O(bc)$ since there can be at most $bc$ pop_back() operations on the ballots. Note that it is not $O(bbc)$ despite there being $O(b)$ calls to an $O(bc)$ function (process_candidate()) as the pop_back() operations are amortized.