#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>
// Constants
#define STD_HOURS 40.0
#define OT_RATE 1.5
#define MA_TAX_RATE 0.05
#define NH_TAX_RATE 0.0
#define VT_TAX_RATE 0.06
#define CA_TAX_RATE 0.07
#define DEFAULT_STATE_TAX_RATE 0.08
#define TAX_STATE_SIZE 3
#define FED_TAX_RATE 0.25
#define FIRST_NAME_SIZE 10
#define LAST_NAME_SIZE 10
// Macros
#define CALC_OT_HOURS(h) ((h) > STD_HOURS ? (h) - STD_HOURS : 0)
#define CALC_STATE_TAX(p,r) ((p) * (r))
#define CALC_FED_TAX(p) ((p) * FED_TAX_RATE)
#define CALC_NET_PAY(p,st,ft) ((p) - ((st) + (ft)))
#define CALC_NORMAL_PAY(w,h,oh) ((w) * ((h) - (oh)))
#define CALC_OT_PAY(w,oh) ((oh) * (OT_RATE * (w)))
#define CALC_MIN(v,c) ((v) < (c) ? (v) : (c))
#define CALC_MAX(v,c) ((v) > (c) ? (v) : (c))
// Structure declarations
typedef struct {
char firstName[ FIRST_NAME_SIZE] ;
char lastName[ LAST_NAME_SIZE] ;
} Name;
typedef struct employee {
Name empName;
char taxState[ TAX_STATE_SIZE] ;
long clockNumber;
float wageRate;
float hours;
float overtimeHrs;
float grossPay;
float stateTax;
float fedTax;
float netPay;
struct employee * next;
} Employee;
typedef struct {
float total_wageRate;
float total_hours;
float total_overtimeHrs;
float total_grossPay;
float total_stateTax;
float total_fedTax;
float total_netPay;
} Totals;
typedef struct {
float min_wageRate, min_hours, min_overtimeHrs, min_grossPay;
float min_stateTax, min_fedTax, min_netPay;
float max_wageRate, max_hours, max_overtimeHrs, max_grossPay;
float max_stateTax, max_fedTax, max_netPay;
} MinMax;
// Function prototypes
Employee * getEmployees( ) ;
int countEmployees( Employee * head) ;
void calculateOvertime( Employee * head) ;
void calculateGrossPay( Employee * head) ;
void calculateStateTax( Employee * head) ;
void calculateFederalTax( Employee * head) ;
void calculateNetPay( Employee * head) ;
void calculateTotals( Employee * head, Totals * totals) ;
void calculateMinMax( Employee * head, MinMax * mm) ;
void printHeader( ) ;
void printEmployee( Employee * head) ;
void printStatistics( Totals * totals, MinMax * mm, int count) ;
void freeEmployees( Employee * head) ;
int main( ) {
Employee * head = NULL;
Totals totals = { 0 } ;
MinMax minmax = { 0 } ;
int employeeCount = 0 ;
head = getEmployees( ) ;
employeeCount = countEmployees( head) ;
if ( employeeCount <= 0 ) {
printf ( "\n No employees to process\n " ) ; return 0 ;
}
calculateOvertime( head) ;
calculateGrossPay( head) ;
calculateStateTax( head) ;
calculateFederalTax( head) ;
calculateNetPay( head) ;
calculateTotals( head, & totals) ;
calculateMinMax( head, & minmax) ;
printHeader( ) ;
printEmployee( head) ;
printStatistics( & totals, & minmax, employeeCount) ;
freeEmployees( head) ;
printf ( "\n Program completed successfully\n " ) ; return 0 ;
}
//Input Functions with Error Checking for ideone compatibility
Employee * getEmployees( ) {
Employee * head = NULL, * current = NULL, * prev = NULL;
char choice[ 4 ] ;
int first = 1 ;
while ( 1 ) {
Employee
* newEmp
= ( Employee
* ) malloc ( sizeof ( Employee
) ) ; if ( ! newEmp) {
printf ( "Memory allocation failed!\n " ) ; }
// Input validation for all fields
printf ( "\n Enter first name: " ) ; if ( scanf ( "%9s" , newEmp
-> empName.
firstName ) != 1 ) { }
if ( scanf ( "%9s" , newEmp
-> empName.
lastName ) != 1 ) { }
printf ( "Enter tax state (2 chars): " ) ; if ( scanf ( "%2s" , newEmp
-> taxState
) != 1 ) { }
printf ( "Enter clock number: " ) ; if ( scanf ( "%ld" , & newEmp
-> clockNumber
) != 1 ) { }
printf ( "Enter hourly wage: " ) ; if ( scanf ( "%f" , & newEmp
-> wageRate
) != 1 ) { }
printf ( "Enter hours worked: " ) ; if ( scanf ( "%f" , & newEmp
-> hours
) != 1 ) { }
// Initialize pointers
newEmp-> next = NULL;
if ( first) {
head = current = newEmp;
first = 0 ;
} else {
prev-> next = newEmp;
current = newEmp;
}
prev = current;
// Add another employee?
printf ( "\n Add another employee? (yes/no): " ) ; if ( scanf ( "%3s" , choice
) != 1 ) { freeEmployees( head) ;
}
if ( toupper ( choice
[ 0 ] ) != 'Y' ) break ; }
return head;
}
void calculateOvertime( Employee * head) {
while ( head) {
head-> overtimeHrs = CALC_OT_HOURS( head-> hours) ;
head = head-> next;
}
}
void calculateGrossPay( Employee * head) {
while ( head) {
float normal = CALC_NORMAL_PAY( head-> wageRate, head-> hours, head-> overtimeHrs) ;
float overtime = CALC_OT_PAY( head-> wageRate, head-> overtimeHrs) ;
head-> grossPay = normal + overtime;
head = head-> next;
}
}
void calculateStateTax( Employee * head) {
while ( head) {
// Convert state code to uppercase
for ( int i = 0 ; i < 2 ; i++ ) {
head
-> taxState
[ i
] = toupper ( head
-> taxState
[ i
] ) ; }
float rate;
if ( strcmp ( head
-> taxState
, "MA" ) == 0 ) rate
= MA_TAX_RATE
; else if ( strcmp ( head
-> taxState
, "VT" ) == 0 ) rate
= VT_TAX_RATE
; else if ( strcmp ( head
-> taxState
, "NH" ) == 0 ) rate
= NH_TAX_RATE
; else if ( strcmp ( head
-> taxState
, "CA" ) == 0 ) rate
= CA_TAX_RATE
; else rate = DEFAULT_STATE_TAX_RATE;
head-> stateTax = CALC_STATE_TAX( head-> grossPay, rate) ;
head = head-> next;
}
}
void calculateFederalTax( Employee * head) {
while ( head) {
head-> fedTax = CALC_FED_TAX( head-> grossPay) ;
head = head-> next;
}
}
void calculateNetPay( Employee * head) {
while ( head) {
head-> netPay = CALC_NET_PAY( head-> grossPay, head-> stateTax, head-> fedTax) ;
head = head-> next;
}
}
//Calculations
void calculateTotals( Employee * head, Totals * t) {
while ( head) {
t-> total_wageRate += head-> wageRate;
t-> total_hours += head-> hours;
t-> total_overtimeHrs += head-> overtimeHrs;
t-> total_grossPay += head-> grossPay;
t-> total_stateTax += head-> stateTax;
t-> total_fedTax += head-> fedTax;
t-> total_netPay += head-> netPay;
head = head-> next;
}
}
void calculateMinMax( Employee * head, MinMax * mm) {
if ( ! head) return ;
// Initialize with first employee
mm-> min_wageRate = mm-> max_wageRate = head-> wageRate;
mm-> min_hours = mm-> max_hours = head-> hours;
mm-> min_overtimeHrs = mm-> max_overtimeHrs = head-> overtimeHrs;
mm-> min_grossPay = mm-> max_grossPay = head-> grossPay;
mm-> min_stateTax = mm-> max_stateTax = head-> stateTax;
mm-> min_fedTax = mm-> max_fedTax = head-> fedTax;
mm-> min_netPay = mm-> max_netPay = head-> netPay;
// Process remaining employees
while ( ( head = head-> next) ) {
mm-> min_wageRate = CALC_MIN( head-> wageRate, mm-> min_wageRate) ;
mm-> max_wageRate = CALC_MAX( head-> wageRate, mm-> max_wageRate) ;
mm-> min_hours = CALC_MIN( head-> hours, mm-> min_hours) ;
mm-> max_hours = CALC_MAX( head-> hours, mm-> max_hours) ;
mm-> min_overtimeHrs = CALC_MIN( head-> overtimeHrs, mm-> min_overtimeHrs) ;
mm-> max_overtimeHrs = CALC_MAX( head-> overtimeHrs, mm-> max_overtimeHrs) ;
mm-> min_grossPay = CALC_MIN( head-> grossPay, mm-> min_grossPay) ;
mm-> max_grossPay = CALC_MAX( head-> grossPay, mm-> max_grossPay) ;
mm-> min_stateTax = CALC_MIN( head-> stateTax, mm-> min_stateTax) ;
mm-> max_stateTax = CALC_MAX( head-> stateTax, mm-> max_stateTax) ;
mm-> min_fedTax = CALC_MIN( head-> fedTax, mm-> min_fedTax) ;
mm-> max_fedTax = CALC_MAX( head-> fedTax, mm-> max_fedTax) ;
mm-> min_netPay = CALC_MIN( head-> netPay, mm-> min_netPay) ;
mm-> max_netPay = CALC_MAX( head-> netPay, mm-> max_netPay) ;
}
}
// Output Functions
void printHeader( ) {
printf ( "\n \n *** Pay Calculator ***\n " ) ; printf ( "--------------------------------------------------------------\n " ) ; printf ( "%-20s %-6s %-10s %-6s %-5s %-8s %-8s %-8s\n " , "Name" , "State" , "Clock#" , "Wage" , "Hours" , "Gross" , "State Tax" ,
"Fed Tax" , "Net Pay" ) ;
printf ( "--------------------------------------------------------------\n " ) ; }
void printEmployee( Employee * head) {
while ( head) {
char fullName[ FIRST_NAME_SIZE + LAST_NAME_SIZE + 2 ] ;
snprintf ( fullName
, sizeof ( fullName
) , "%s %s" , head-> empName.firstName , head-> empName.lastName ) ;
printf ( "%-20s %-6s %-10ld %-6.2f %-5.1f %-8.2f %-8.2f %-8.2f %-8.2f\n " , fullName,
head-> taxState,
head-> clockNumber,
head-> wageRate,
head-> hours,
head-> grossPay,
head-> stateTax,
head-> fedTax,
head-> netPay) ;
head = head-> next;
}
}
void printStatistics( Totals * t, MinMax * mm, int count) {
printf ( "\n --- Payroll Statistics ---\n " ) ; printf ( " Wages: $%.2f Hours: %.1f OT: %.1f\n " , t-> total_wageRate, t-> total_hours, t-> total_overtimeHrs) ;
printf ( " Gross: $%.2f State Tax: $%.2f Federal Tax: $%.2f Net: $%.2f\n " , t-> total_grossPay, t-> total_stateTax, t-> total_fedTax, t-> total_netPay) ;
printf ( "\n Averages (%d employees):\n " , count
) ; printf ( " Wage: $%.2f/hr Hours: %.1f OT: %.1f\n " , t-> total_wageRate/ count, t-> total_hours/ count, t-> total_overtimeHrs/ count) ;
printf ( " Gross: $%.2f Net: $%.2f\n " , t-> total_grossPay/ count, t-> total_netPay/ count) ;
printf ( " Wage: $%.2f Hours: %.1f Gross: $%.2f Net: $%.2f\n " , mm-> min_wageRate, mm-> min_hours, mm-> min_grossPay, mm-> min_netPay) ;
printf ( " Wage: $%.2f Hours: %.1f Gross: $%.2f Net: $%.2f\n " , mm-> max_wageRate, mm-> max_hours, mm-> max_grossPay, mm-> max_netPay) ;
}
/********************************************************
* Utility Functions
********************************************************/
int countEmployees( Employee * head) {
int count = 0 ;
while ( head) {
count++;
head = head-> next;
}
return count;
}
void freeEmployees( Employee * head) {
while ( head) {
Employee * temp = head;
head = head-> next;
}
}
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>

// Constants
#define STD_HOURS 40.0
#define OT_RATE 1.5
#define MA_TAX_RATE 0.05
#define NH_TAX_RATE 0.0
#define VT_TAX_RATE 0.06
#define CA_TAX_RATE 0.07
#define DEFAULT_STATE_TAX_RATE 0.08
#define TAX_STATE_SIZE 3
#define FED_TAX_RATE 0.25
#define FIRST_NAME_SIZE 10
#define LAST_NAME_SIZE 10

// Macros
#define CALC_OT_HOURS(h) ((h) > STD_HOURS ? (h) - STD_HOURS : 0)
#define CALC_STATE_TAX(p,r) ((p) * (r))
#define CALC_FED_TAX(p) ((p) * FED_TAX_RATE)
#define CALC_NET_PAY(p,st,ft) ((p) - ((st) + (ft)))
#define CALC_NORMAL_PAY(w,h,oh) ((w) * ((h) - (oh)))
#define CALC_OT_PAY(w,oh) ((oh) * (OT_RATE * (w)))
#define CALC_MIN(v,c) ((v) < (c) ? (v) : (c))
#define CALC_MAX(v,c) ((v) > (c) ? (v) : (c))

// Structure declarations
typedef struct {
    char firstName[FIRST_NAME_SIZE];
    char lastName[LAST_NAME_SIZE];
} Name;

typedef struct employee {
    Name empName;
    char taxState[TAX_STATE_SIZE];
    long clockNumber;
    float wageRate;
    float hours;
    float overtimeHrs;
    float grossPay;
    float stateTax;
    float fedTax;
    float netPay;
    struct employee *next;
} Employee;

typedef struct {
    float total_wageRate;
    float total_hours;
    float total_overtimeHrs;
    float total_grossPay;
    float total_stateTax;
    float total_fedTax;
    float total_netPay;
} Totals;

typedef struct {
    float min_wageRate, min_hours, min_overtimeHrs, min_grossPay;
    float min_stateTax, min_fedTax, min_netPay;
    float max_wageRate, max_hours, max_overtimeHrs, max_grossPay;
    float max_stateTax, max_fedTax, max_netPay;
} MinMax;

// Function prototypes
Employee *getEmployees();
int countEmployees(Employee *head);
void calculateOvertime(Employee *head);
void calculateGrossPay(Employee *head);
void calculateStateTax(Employee *head);
void calculateFederalTax(Employee *head);
void calculateNetPay(Employee *head);
void calculateTotals(Employee *head, Totals *totals);
void calculateMinMax(Employee *head, MinMax *mm);
void printHeader();
void printEmployee(Employee *head);
void printStatistics(Totals *totals, MinMax *mm, int count);
void freeEmployees(Employee *head);

int main() {
    Employee *head = NULL;
    Totals totals = {0};
    MinMax minmax = {0};
    int employeeCount = 0;

    head = getEmployees();
    employeeCount = countEmployees(head);

    if (employeeCount <= 0) {
        printf("\nNo employees to process\n");
        return 0;
    }

    calculateOvertime(head);
    calculateGrossPay(head);
    calculateStateTax(head);
    calculateFederalTax(head);
    calculateNetPay(head);
    calculateTotals(head, &totals);
    calculateMinMax(head, &minmax);

    printHeader();
    printEmployee(head);
    printStatistics(&totals, &minmax, employeeCount);

    freeEmployees(head);
    printf("\nProgram completed successfully\n");
    return 0;
}


//Input Functions with Error Checking for ideone compatibility 

Employee *getEmployees() {
    Employee *head = NULL, *current = NULL, *prev = NULL;
    char choice[4];
    int first = 1;

    while(1) {
        Employee *newEmp = (Employee *)malloc(sizeof(Employee));
        if(!newEmp) {
            printf("Memory allocation failed!\n");
            exit(1);
        }

        // Input validation for all fields
        printf("\nEnter first name: ");
        if(scanf("%9s", newEmp->empName.firstName) != 1) {
            printf("Invalid input!\n");
            free(newEmp);
            exit(1);
        }

        printf("Enter last name: ");
        if(scanf("%9s", newEmp->empName.lastName) != 1) {
            printf("Invalid input!\n");
            free(newEmp);
            exit(1);
        }

        printf("Enter tax state (2 chars): ");
        if(scanf("%2s", newEmp->taxState) != 1) {
            printf("Invalid input!\n");
            free(newEmp);
            exit(1);
        }

        printf("Enter clock number: ");
        if(scanf("%ld", &newEmp->clockNumber) != 1) {
            printf("Invalid input!\n");
            free(newEmp);
            exit(1);
        }

        printf("Enter hourly wage: ");
        if(scanf("%f", &newEmp->wageRate) != 1) {
            printf("Invalid input!\n");
            free(newEmp);
            exit(1);
        }

        printf("Enter hours worked: ");
        if(scanf("%f", &newEmp->hours) != 1) {
            printf("Invalid input!\n");
            free(newEmp);
            exit(1);
        }

        // Initialize pointers
        newEmp->next = NULL;
        if(first) {
            head = current = newEmp;
            first = 0;
        } else {
            prev->next = newEmp;
            current = newEmp;
        }
        prev = current;

        // Add another employee?
        printf("\nAdd another employee? (yes/no): ");
        if(scanf("%3s", choice) != 1) {
            printf("Invalid input!\n");
            freeEmployees(head);
            exit(1);
        }
        if(toupper(choice[0]) != 'Y') break;
    }
    return head;
}

void calculateOvertime(Employee *head) {
    while(head) {
        head->overtimeHrs = CALC_OT_HOURS(head->hours);
        head = head->next;
    }
}

void calculateGrossPay(Employee *head) {
    while(head) {
        float normal = CALC_NORMAL_PAY(head->wageRate, head->hours, head->overtimeHrs);
        float overtime = CALC_OT_PAY(head->wageRate, head->overtimeHrs);
        head->grossPay = normal + overtime;
        head = head->next;
    }
}

void calculateStateTax(Employee *head) {
    while(head) {
        // Convert state code to uppercase
        for(int i = 0; i < 2; i++) {
            head->taxState[i] = toupper(head->taxState[i]);
        }

        float rate;
        if(strcmp(head->taxState, "MA") == 0) rate = MA_TAX_RATE;
        else if(strcmp(head->taxState, "VT") == 0) rate = VT_TAX_RATE;
        else if(strcmp(head->taxState, "NH") == 0) rate = NH_TAX_RATE;
        else if(strcmp(head->taxState, "CA") == 0) rate = CA_TAX_RATE;
        else rate = DEFAULT_STATE_TAX_RATE;

        head->stateTax = CALC_STATE_TAX(head->grossPay, rate);
        head = head->next;
    }
}

void calculateFederalTax(Employee *head) {
    while(head) {
        head->fedTax = CALC_FED_TAX(head->grossPay);
        head = head->next;
    }
}

void calculateNetPay(Employee *head) {
    while(head) {
        head->netPay = CALC_NET_PAY(head->grossPay, head->stateTax, head->fedTax);
        head = head->next;
    }
}

//Calculations

void calculateTotals(Employee *head, Totals *t) {
    while(head) {
        t->total_wageRate += head->wageRate;
        t->total_hours += head->hours;
        t->total_overtimeHrs += head->overtimeHrs;
        t->total_grossPay += head->grossPay;
        t->total_stateTax += head->stateTax;
        t->total_fedTax += head->fedTax;
        t->total_netPay += head->netPay;
        head = head->next;
    }
}

void calculateMinMax(Employee *head, MinMax *mm) {
    if(!head) return;

    // Initialize with first employee
    mm->min_wageRate = mm->max_wageRate = head->wageRate;
    mm->min_hours = mm->max_hours = head->hours;
    mm->min_overtimeHrs = mm->max_overtimeHrs = head->overtimeHrs;
    mm->min_grossPay = mm->max_grossPay = head->grossPay;
    mm->min_stateTax = mm->max_stateTax = head->stateTax;
    mm->min_fedTax = mm->max_fedTax = head->fedTax;
    mm->min_netPay = mm->max_netPay = head->netPay;

    // Process remaining employees
    while((head = head->next)) {
        mm->min_wageRate = CALC_MIN(head->wageRate, mm->min_wageRate);
        mm->max_wageRate = CALC_MAX(head->wageRate, mm->max_wageRate);
        
        mm->min_hours = CALC_MIN(head->hours, mm->min_hours);
        mm->max_hours = CALC_MAX(head->hours, mm->max_hours);
        
        mm->min_overtimeHrs = CALC_MIN(head->overtimeHrs, mm->min_overtimeHrs);
        mm->max_overtimeHrs = CALC_MAX(head->overtimeHrs, mm->max_overtimeHrs);
        
        mm->min_grossPay = CALC_MIN(head->grossPay, mm->min_grossPay);
        mm->max_grossPay = CALC_MAX(head->grossPay, mm->max_grossPay);
        
        mm->min_stateTax = CALC_MIN(head->stateTax, mm->min_stateTax);
        mm->max_stateTax = CALC_MAX(head->stateTax, mm->max_stateTax);
        
        mm->min_fedTax = CALC_MIN(head->fedTax, mm->min_fedTax);
        mm->max_fedTax = CALC_MAX(head->fedTax, mm->max_fedTax);
        
        mm->min_netPay = CALC_MIN(head->netPay, mm->min_netPay);
        mm->max_netPay = CALC_MAX(head->netPay, mm->max_netPay);
    }
}


// Output Functions

void printHeader() {
    printf("\n\n*** Pay Calculator ***\n");
    printf("--------------------------------------------------------------\n");
    printf("%-20s %-6s %-10s %-6s %-5s %-8s %-8s %-8s\n", 
           "Name", "State", "Clock#", "Wage", "Hours", "Gross", "State Tax", 
           "Fed Tax", "Net Pay");
    printf("--------------------------------------------------------------\n");
}

void printEmployee(Employee *head) {
    while(head) {
        char fullName[FIRST_NAME_SIZE + LAST_NAME_SIZE + 2];
        snprintf(fullName, sizeof(fullName), "%s %s", 
                head->empName.firstName, head->empName.lastName);
        
        printf("%-20s %-6s %-10ld %-6.2f %-5.1f %-8.2f %-8.2f %-8.2f %-8.2f\n",
               fullName,
               head->taxState,
               head->clockNumber,
               head->wageRate,
               head->hours,
               head->grossPay,
               head->stateTax,
               head->fedTax,
               head->netPay);
        
        head = head->next;
    }
}

void printStatistics(Totals *t, MinMax *mm, int count) {
    printf("\n--- Payroll Statistics ---\n");
    printf("Totals:\n");
    printf(" Wages: $%.2f  Hours: %.1f  OT: %.1f\n", 
           t->total_wageRate, t->total_hours, t->total_overtimeHrs);
    printf(" Gross: $%.2f  State Tax: $%.2f  Federal Tax: $%.2f  Net: $%.2f\n",
           t->total_grossPay, t->total_stateTax, t->total_fedTax, t->total_netPay);

    printf("\nAverages (%d employees):\n", count);
    printf(" Wage: $%.2f/hr  Hours: %.1f  OT: %.1f\n",
           t->total_wageRate/count, t->total_hours/count, t->total_overtimeHrs/count);
    printf(" Gross: $%.2f  Net: $%.2f\n",
           t->total_grossPay/count, t->total_netPay/count);

    printf("\nMinimums:\n");
    printf(" Wage: $%.2f  Hours: %.1f  Gross: $%.2f  Net: $%.2f\n",
           mm->min_wageRate, mm->min_hours, mm->min_grossPay, mm->min_netPay);
    
    printf("\nMaximums:\n");
    printf(" Wage: $%.2f  Hours: %.1f  Gross: $%.2f  Net: $%.2f\n",
           mm->max_wageRate, mm->max_hours, mm->max_grossPay, mm->max_netPay);
}

/********************************************************
* Utility Functions
********************************************************/
int countEmployees(Employee *head) {
    int count = 0;
    while(head) {
        count++;
        head = head->next;
    }
    return count;
}

void freeEmployees(Employee *head) {
    while(head) {
        Employee *temp = head;
        head = head->next;
        free(temp);
    }
}