//*******************************************************
//
// Assignment 4 - Arrays
//
// Name: Marin Haxhiaj
//
// Class: C Programming, Spring 2025
//
// Date: 02/20/2025
//
// Description: Program which determines overtime and
// gross pay for a set of employees with outputs sent
// to standard output (the screen).
//
//********************************************************
#include <stdio.h>
#define SIZE 5 // Number of employees to process
#define STD_HOURS 40.0 // Standard work week hours before overtime
#define OT_RATE 1.5 // Overtime pay factor
int main() {
long int clockNumber[SIZE] = {98401, 526488, 765349, 34645, 127615};
float wageRate[SIZE] = {10.6, 9.75, 10.5, 12.25, 8.35};
float hours[SIZE];
float overtimeHrs[SIZE], normalPay[SIZE], overtimePay[SIZE], grossPay[SIZE];
int i;
float totalHours = 0, totalOvertimeHrs = 0, totalOvertimePay = 0, totalGrossPay = 0;
printf("\n*** Pay Calculator ***\n\n");
for (i = 0; i < SIZE; i++) {
}
for (i = 0; i < SIZE; i++) {
if (hours[i] > STD_HOURS) {
overtimeHrs[i] = hours[i] - STD_HOURS;
normalPay[i] = STD_HOURS * wageRate[i];
overtimePay[i] = overtimeHrs[i] * wageRate[i] * OT_RATE;
} else {
overtimeHrs[i] = 0;
normalPay[i] = hours[i] * wageRate[i];
overtimePay[i] = 0;
}
grossPay[i] = normalPay[i] + overtimePay[i];
totalHours += hours[i];
totalOvertimeHrs += overtimeHrs[i];
totalOvertimePay += overtimePay[i];
totalGrossPay += grossPay[i];
}
printf("\n%-10s %-10s %-10s %-10s %-10s %-10s\n", "Clock#", "Wage", "Hours", "OT Hours", "OT Pay", "Gross Pay"); printf("-------------------------------------------------------------------------------\n");
for (i = 0; i < SIZE; i++) {
printf("%06ld $%7.2f %7.2f %7.2f $%7.2f $%7.2f\n", clockNumber[i], wageRate[i], hours[i], overtimeHrs[i], overtimePay[i], grossPay[i]);
}
printf("-------------------------------------------------------------------------------\n"); printf("%-10s %-10s %7.2f %7.2f $%7.2f $%7.2f\n", "TOTALS", "", totalHours
, totalOvertimeHrs
, totalOvertimePay
, totalGrossPay
);
return 0;
}
Ly8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCi8vCi8vIEFzc2lnbm1lbnQgNCAtIEFycmF5cwovLwovLyBOYW1lOiBNYXJpbiBIYXhoaWFqCi8vCi8vIENsYXNzOiBDIFByb2dyYW1taW5nLCBTcHJpbmcgMjAyNQovLwovLyBEYXRlOiAwMi8yMC8yMDI1Ci8vCi8vIERlc2NyaXB0aW9uOiBQcm9ncmFtIHdoaWNoIGRldGVybWluZXMgb3ZlcnRpbWUgYW5kIAovLyBncm9zcyBwYXkgZm9yIGEgc2V0IG9mIGVtcGxveWVlcyB3aXRoIG91dHB1dHMgc2VudCAKLy8gdG8gc3RhbmRhcmQgb3V0cHV0ICh0aGUgc2NyZWVuKS4KLy8KLy8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoKI2luY2x1ZGUgPHN0ZGlvLmg+CgoKI2RlZmluZSBTSVpFIDUgICAgICAgICAgIC8vIE51bWJlciBvZiBlbXBsb3llZXMgdG8gcHJvY2VzcwojZGVmaW5lIFNURF9IT1VSUyA0MC4wICAgLy8gU3RhbmRhcmQgd29yayB3ZWVrIGhvdXJzIGJlZm9yZSBvdmVydGltZQojZGVmaW5lIE9UX1JBVEUgMS41ICAgICAgLy8gT3ZlcnRpbWUgcGF5IGZhY3RvcgoKaW50IG1haW4oKSB7CiAgICBsb25nIGludCBjbG9ja051bWJlcltTSVpFXSA9IHs5ODQwMSwgNTI2NDg4LCA3NjUzNDksIDM0NjQ1LCAxMjc2MTV9OwogICAgZmxvYXQgd2FnZVJhdGVbU0laRV0gPSB7MTAuNiwgOS43NSwgMTAuNSwgMTIuMjUsIDguMzV9OwogICAgZmxvYXQgaG91cnNbU0laRV07CiAgICBmbG9hdCBvdmVydGltZUhyc1tTSVpFXSwgbm9ybWFsUGF5W1NJWkVdLCBvdmVydGltZVBheVtTSVpFXSwgZ3Jvc3NQYXlbU0laRV07CiAgICBpbnQgaTsKICAgIGZsb2F0IHRvdGFsSG91cnMgPSAwLCB0b3RhbE92ZXJ0aW1lSHJzID0gMCwgdG90YWxPdmVydGltZVBheSA9IDAsIHRvdGFsR3Jvc3NQYXkgPSAwOwoKICAgIHByaW50ZigiXG4qKiogUGF5IENhbGN1bGF0b3IgKioqXG5cbiIpOwoKICAgIGZvciAoaSA9IDA7IGkgPCBTSVpFOyBpKyspIHsKICAgICAgICBzY2FuZigiJWYiLCAmaG91cnNbaV0pOwogICAgfQoKICAgIGZvciAoaSA9IDA7IGkgPCBTSVpFOyBpKyspIHsKICAgICAgICBpZiAoaG91cnNbaV0gPiBTVERfSE9VUlMpIHsKICAgICAgICAgICAgb3ZlcnRpbWVIcnNbaV0gPSBob3Vyc1tpXSAtIFNURF9IT1VSUzsKICAgICAgICAgICAgbm9ybWFsUGF5W2ldID0gU1REX0hPVVJTICogd2FnZVJhdGVbaV07CiAgICAgICAgICAgIG92ZXJ0aW1lUGF5W2ldID0gb3ZlcnRpbWVIcnNbaV0gKiB3YWdlUmF0ZVtpXSAqIE9UX1JBVEU7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgb3ZlcnRpbWVIcnNbaV0gPSAwOwogICAgICAgICAgICBub3JtYWxQYXlbaV0gPSBob3Vyc1tpXSAqIHdhZ2VSYXRlW2ldOwogICAgICAgICAgICBvdmVydGltZVBheVtpXSA9IDA7CiAgICAgICAgfQogICAgICAgIGdyb3NzUGF5W2ldID0gbm9ybWFsUGF5W2ldICsgb3ZlcnRpbWVQYXlbaV07CiAgICAgICAgCiAgICAgICAgdG90YWxIb3VycyArPSBob3Vyc1tpXTsKICAgICAgICB0b3RhbE92ZXJ0aW1lSHJzICs9IG92ZXJ0aW1lSHJzW2ldOwogICAgICAgIHRvdGFsT3ZlcnRpbWVQYXkgKz0gb3ZlcnRpbWVQYXlbaV07CiAgICAgICAgdG90YWxHcm9zc1BheSArPSBncm9zc1BheVtpXTsKICAgIH0KCiAgICBwcmludGYoIlxuJS0xMHMgJS0xMHMgJS0xMHMgJS0xMHMgJS0xMHMgJS0xMHNcbiIsICJDbG9jayMiLCAiV2FnZSIsICJIb3VycyIsICJPVCBIb3VycyIsICJPVCBQYXkiLCAiR3Jvc3MgUGF5Iik7CiAgICBwcmludGYoIi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbiIpOwogICAgCiAgICBmb3IgKGkgPSAwOyBpIDwgU0laRTsgaSsrKSB7CiAgICAgICAgcHJpbnRmKCIlMDZsZCAgICQlNy4yZiAgICU3LjJmICAgJTcuMmYgICAkJTcuMmYgICAkJTcuMmZcbiIsCiAgICAgICAgICAgICAgIGNsb2NrTnVtYmVyW2ldLCB3YWdlUmF0ZVtpXSwgaG91cnNbaV0sIG92ZXJ0aW1lSHJzW2ldLCBvdmVydGltZVBheVtpXSwgZ3Jvc3NQYXlbaV0pOwogICAgfQogICAgCiAgICBwcmludGYoIi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbiIpOwogICAgcHJpbnRmKCIlLTEwcyAlLTEwcyAlNy4yZiAgICU3LjJmICAgJCU3LjJmICAgJCU3LjJmXG4iLCAiVE9UQUxTIiwgIiIsIHRvdGFsSG91cnMsIHRvdGFsT3ZlcnRpbWVIcnMsIHRvdGFsT3ZlcnRpbWVQYXksIHRvdGFsR3Jvc3NQYXkpOwoKICAgIHJldHVybiAwOwp9