return 0;
};
- @choices = sort $compare, @choices;
+ @choices = sort $compare @choices;
$a = $choices[0];
- my $numequal = 0;
+ my $numequal = 1;
for (;;) {
- last unless $numequal >= @choices;
+ last if $numequal >= @choices;
$b = $choices[$numequal];
last if $compare->();
+ $numequal++;
}
die 'random choice unimplemented' if $numequal > 1;
my $s = $sorted[0];
my $topvoters = $s->{Total};
my $surplus = $topvoters - $quota;
- last unless $surplus > 0;
+ last unless $surplus >= 0;
- printf "%7s %10s ***************\n", 'ELECTED', $s->{Cand};
- push @elected, $s->{Cand};
+ my @elect = equalpiles 'elect?', @sorted;
- foreach my $vote (@{ $s->{Votes} }) {
- votelog $vote, "elected $s->{Cand}";
+ if (@elect > $placesremain) {
+ # oh my god
+ @elect = historically_prefer +1, @elect;
+ printf "%7s %10s\n", 'tie!', $elect[0]{Cand};
}
- $s->{Surplus} = $surplus;
- push @newsurpluses, $s;
- delete $sorted{ $s->{Cand} };
- delete $continuing{ $s->{Cand} };
+ foreach $s (@elect) {
+ printf "%7s %10s ***************\n", 'ELECTED', $s->{Cand};
+ push @elected, $s->{Cand};
+
+ foreach my $vote (@{ $s->{Votes} }) {
+ votelog $vote, "elected $s->{Cand}";
+ }
+
+ $s->{Surplus} = $surplus;
+ push @newsurpluses, $s;
+ delete $sorted{ $s->{Cand} };
+ delete $continuing{ $s->{Cand} };
+ }
$things_update->();
}