Last active
June 11, 2020 16:07
-
-
Save Jonathan-Adly/2287b43d7d67e8ec50c0e968d67495ed to your computer and use it in GitHub Desktop.
CS50 - PSET3
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| #include <cs50.h> | |
| #include <stdio.h> | |
| #include <string.h> | |
| // Max number of candidates | |
| #define MAX 9 | |
| // Candidates have name and vote count | |
| typedef struct | |
| { | |
| string name; | |
| int votes; | |
| } | |
| candidate; | |
| // Array of candidates | |
| candidate candidates[MAX]; | |
| // Number of candidates | |
| int candidate_count; | |
| // Function prototypes | |
| bool vote(string name); | |
| void print_winner(void); | |
| int main(int argc, string argv[]) | |
| { | |
| // Check for invalid usage | |
| if (argc < 2) | |
| { | |
| printf("Usage: plurality [candidate ...]\n"); | |
| return 1; | |
| } | |
| // Populate array of candidates | |
| candidate_count = argc - 1; | |
| if (candidate_count > MAX) | |
| { | |
| printf("Maximum number of candidates is %i\n", MAX); | |
| return 2; | |
| } | |
| for (int i = 0; i < candidate_count; i++) | |
| { | |
| candidates[i].name = argv[i + 1]; | |
| candidates[i].votes = 0; | |
| } | |
| int voter_count = get_int("Number of voters: "); | |
| // Loop over all voters | |
| for (int i = 0; i < voter_count; i++) | |
| { | |
| string name = get_string("Vote: "); | |
| // Check for invalid vote | |
| if (!vote(name)) | |
| { | |
| printf("Invalid vote.\n"); | |
| } | |
| } | |
| // Display winner of election | |
| print_winner(); | |
| } | |
| // Update vote totals given a new vote | |
| bool vote(string name) | |
| { | |
| for (int i = 0; i < candidate_count; i++) | |
| { | |
| if (strcmp(candidates[i].name, name) == 0) | |
| { | |
| candidates[i].votes++; | |
| return true; | |
| } | |
| } | |
| return false; | |
| } | |
| // Print the winner (or winners) of the election | |
| void print_winner(void) | |
| { | |
| int maxvotes = 0; | |
| // find highest number of votes | |
| for (int i = 0; i < candidate_count; i++) | |
| { | |
| if (candidates[i].votes > maxvotes) | |
| { | |
| maxvotes = candidates[i].votes; | |
| } | |
| } | |
| // print winners | |
| for (int i = 0; i < candidate_count; i++) | |
| { | |
| if (candidates[i].votes == maxvotes) | |
| { | |
| printf("%s\n", candidates[i].name); | |
| } | |
| } | |
| // end | |
| return; | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| #include <cs50.h> | |
| #include <stdio.h> | |
| #include <string.h> | |
| // Max voters and candidates | |
| #define MAX_VOTERS 100 | |
| #define MAX_CANDIDATES 9 | |
| // preferences[i][j] is jth preference for voter i | |
| int preferences[MAX_VOTERS][MAX_CANDIDATES]; //preferences is an array composed of max voters/cand | |
| // Candidates have name, vote count, eliminated status | |
| typedef struct | |
| { | |
| string name; | |
| int votes; | |
| bool eliminated; | |
| } | |
| candidate; | |
| // Array of candidates | |
| candidate candidates[MAX_CANDIDATES]; | |
| // Numbers of voters and candidates | |
| int voter_count; | |
| int candidate_count; | |
| // Function prototypes | |
| bool vote(int voter, int rank, string name); | |
| void tabulate(void); | |
| bool print_winner(void); | |
| int find_min(void); | |
| bool is_tie(int min); | |
| void eliminate(int min); | |
| int main(int argc, string argv[]) | |
| { | |
| // Check for invalid usage | |
| if (argc < 2) | |
| { | |
| printf("Usage: runoff [candidate ...]\n"); | |
| return 1; | |
| } | |
| // Populate array of candidates | |
| candidate_count = argc - 1; | |
| if (candidate_count > MAX_CANDIDATES) | |
| { | |
| printf("Maximum number of candidates is %i\n", MAX_CANDIDATES); | |
| return 2; | |
| } | |
| for (int i = 0; i < candidate_count; i++) | |
| { | |
| candidates[i].name = argv[i + 1]; | |
| candidates[i].votes = 0; | |
| candidates[i].eliminated = false; | |
| } | |
| voter_count = get_int("Number of voters: "); | |
| if (voter_count > MAX_VOTERS) | |
| { | |
| printf("Maximum number of voters is %i\n", MAX_VOTERS); | |
| return 3; | |
| } | |
| // Keep querying for votes | |
| for (int i = 0; i < voter_count; i++) | |
| { | |
| // Query for each rank | |
| for (int j = 0; j < candidate_count; j++) | |
| { | |
| string name = get_string("Rank %i: ", j + 1); | |
| // Record vote, unless it's invalid | |
| if (!vote(i, j, name)) | |
| { | |
| printf("Invalid vote.\n"); | |
| return 4; | |
| } | |
| } | |
| printf("\n"); | |
| } | |
| // Keep holding runoffs until winner exists | |
| while (true) | |
| { | |
| // Calculate votes given remaining candidates | |
| tabulate(); | |
| // Check if election has been won | |
| bool won = print_winner(); | |
| if (won) | |
| { | |
| break; | |
| } | |
| // Eliminate last-place candidates | |
| int min = find_min(); | |
| bool tie = is_tie(min); | |
| // If tie, everyone wins | |
| if (tie) | |
| { | |
| for (int i = 0; i < candidate_count; i++) | |
| { | |
| if (!candidates[i].eliminated) | |
| { | |
| printf("%s\n", candidates[i].name); | |
| } | |
| } | |
| break; | |
| } | |
| // Eliminate anyone with minimum number of votes | |
| eliminate(min); | |
| // Reset vote counts back to zero | |
| for (int i = 0; i < candidate_count; i++) | |
| { | |
| candidates[i].votes = 0; | |
| } | |
| } | |
| return 0; | |
| } | |
| // Record preference if vote is valid | |
| bool vote(int voter, int rank, string name) | |
| { | |
| for (int x = 0; x < candidate_count; x++) // Ititrate through voters, looking for the candidate name | |
| { | |
| if (strcmp(candidates[x].name, name) == 0) | |
| { | |
| preferences [voter][rank] = x; //record the vote | |
| return true; | |
| } | |
| } | |
| return false; | |
| } | |
| // Tabulate votes for non-eliminated candidates | |
| void tabulate(void) | |
| { | |
| for (int v = 0; v < voter_count; v++) // itirate through voters | |
| { | |
| for (int r = 0; r < candidate_count; r++) // itirate through voters choice | |
| { | |
| if (candidates[preferences[v][r]].eliminated == false) //if they are not eliminated | |
| { | |
| candidates[preferences[v][r]].votes++; //add their votes | |
| break; | |
| } | |
| } | |
| } | |
| return; | |
| } | |
| // Print the winner of the election, if there is one | |
| bool print_winner(void) | |
| { | |
| for (int c = 0; c < candidate_count; c++) | |
| { | |
| if (candidates[c].votes > (voter_count * 0.5)) | |
| { | |
| printf("%s\n", candidates[c].name); | |
| return true; | |
| } | |
| } | |
| return false; | |
| } | |
| // Return the minimum number of votes any remaining candidate has | |
| int find_min(void) | |
| { | |
| int min[1] = {0}; | |
| for (int c = 0; c < candidate_count; c++) | |
| { | |
| if (candidates[c].votes > min[0]) | |
| { | |
| min[0] = candidates[c].votes; | |
| } | |
| } | |
| return min[0]; | |
| } | |
| // Return true if the election is tied between all candidates, false otherwise | |
| bool is_tie(int min) | |
| { | |
| for (int c = 0; c < candidate_count; c++) | |
| { | |
| if (candidates[c].votes != min && candidates[c].eliminated == false) | |
| { | |
| return false; | |
| } | |
| } | |
| return true; | |
| } | |
| // Eliminate the candidate (or candidiates) in last place | |
| void eliminate(int min) | |
| { | |
| for (int c = 0; c < candidate_count; c++) | |
| { | |
| if (candidates[c].votes == min) | |
| { | |
| candidates[c].eliminated = true; | |
| } | |
| } | |
| return; | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment