//********************************************************
//
// Assignment 7 - Structures and Strings
//
// Name: Your Name
// Class: C Programming, Spring 2026
// Date: Current Date
//
//********************************************************
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#define SIZE 5
#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_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
struct name
{
char firstName[FIRST_NAME_SIZE];
char lastName[LAST_NAME_SIZE];
};
struct employee
{
struct name empName;
char taxState[TAX_STATE_SIZE];
long int clockNumber;
float wageRate;
float hours;
float overtimeHrs;
float grossPay;
float stateTax;
float fedTax;
float netPay;
};
struct totals
{
float total_wageRate;
float total_hours;
float total_overtimeHrs;
float total_grossPay;
float total_stateTax;
float total_fedTax;
float total_netPay;
};
struct min_max
{
float min_wageRate, min_hours, min_overtimeHrs, min_grossPay, min_stateTax, min_fedTax, min_netPay;
float max_wageRate, max_hours, max_overtimeHrs, max_grossPay, max_stateTax, max_fedTax, max_netPay;
};
// function prototypes
void getHours(struct employee[], int);
void calcOvertimeHrs(struct employee[], int);
void calcGrossPay(struct employee[], int);
void calcStateTax(struct employee[], int);
void calcFedTax(struct employee[], int);
void calcNetPay(struct employee[], int);
void printHeader(void);
void printEmp(struct employee[], int);
struct totals calcEmployeeTotals(struct employee[], struct totals, int);
struct min_max calcEmployeeMinMax(struct employee[], struct min_max, int);
void printEmpStatistics(struct totals, struct min_max, int);
int main()
{
struct employee employeeData[SIZE] = {
{ {"Connie", "Cobol"}, "MA", 98401, 10.60},
{ {"Mary", "Apl"}, "NH", 526488, 9.75 },
{ {"Frank", "Fortran"}, "VT", 765349, 10.50 },
{ {"Jeff", "Ada"}, "NY", 34645, 12.25 },
{ {"Anton", "Pascal"},"CA",127615, 8.35 }
};
struct totals employeeTotals = {0};
struct min_max employeeMinMax = {0};
getHours(employeeData, SIZE);
calcOvertimeHrs(employeeData, SIZE);
calcGrossPay(employeeData, SIZE);
calcStateTax(employeeData, SIZE);
calcFedTax(employeeData, SIZE);
calcNetPay(employeeData, SIZE);
employeeTotals = calcEmployeeTotals(employeeData, employeeTotals, SIZE);
employeeMinMax = calcEmployeeMinMax(employeeData, employeeMinMax, SIZE);
printHeader();
printEmp(employeeData, SIZE);
printEmpStatistics(employeeTotals, employeeMinMax, SIZE);
return 0;
}
//---------------- FUNCTIONS ----------------//
void getHours(struct employee e[], int size)
{
for (int i = 0; i < size; i++)
{
printf("\nEnter hours worked by emp # %06li: ", e
[i
].
clockNumber); scanf("%f", &e
[i
].
hours); }
}
void calcOvertimeHrs(struct employee e[], int size)
{
for (int i = 0; i < size; i++)
e[i].overtimeHrs = (e[i].hours > STD_HOURS) ? (e[i].hours - STD_HOURS) : 0;
}
void calcGrossPay(struct employee e[], int size)
{
for (int i = 0; i < size; i++)
{
float normal = (e[i].hours - e[i].overtimeHrs) * e[i].wageRate;
float overtime = e[i].overtimeHrs * OT_RATE * e[i].wageRate;
e[i].grossPay = normal + overtime;
}
}
void calcStateTax(struct employee e[], int size)
{
for (int i = 0; i < size; i++)
{
if (strcmp(e
[i
].
taxState, "MA") == 0) e[i].stateTax = e[i].grossPay * MA_TAX_RATE;
else if (strcmp(e
[i
].
taxState, "NH") == 0) e[i].stateTax = e[i].grossPay * NH_TAX_RATE;
else if (strcmp(e
[i
].
taxState, "VT") == 0) e[i].stateTax = e[i].grossPay * VT_TAX_RATE;
else if (strcmp(e
[i
].
taxState, "CA") == 0) e[i].stateTax = e[i].grossPay * CA_TAX_RATE;
else
e[i].stateTax = e[i].grossPay * DEFAULT_TAX_RATE;
}
}
void calcFedTax(struct employee e[], int size)
{
for (int i = 0; i < size; i++)
e[i].fedTax = e[i].grossPay * FED_TAX_RATE;
}
void calcNetPay(struct employee e[], int size)
{
for (int i = 0; i < size; i++)
e[i].netPay = e[i].grossPay - (e[i].stateTax + e[i].fedTax);
}
void printHeader(void)
{
printf("\n\n*** Pay Calculator ***\n"); printf("\n---------------------------------------------------------------------------------"); printf("\nName Tax Clock# Wage Hours OT Gross State Fed Net"); printf("\n State Pay Tax Tax Pay"); printf("\n---------------------------------------------------------------------------------"); }
void printEmp(struct employee e[], int size)
{
char name[25];
for (int i = 0; i < size; i++)
{
strcpy(name
, e
[i
].
empName.
firstName); strcat(name
, e
[i
].
empName.
lastName);
printf("\n%-20s %-2s %06li %6.2f %6.1f %5.1f %7.2f %6.2f %7.2f %8.2f", name, e[i].taxState, e[i].clockNumber,
e[i].wageRate, e[i].hours, e[i].overtimeHrs,
e[i].grossPay, e[i].stateTax,
e[i].fedTax, e[i].netPay);
}
}
struct totals calcEmployeeTotals(struct employee e[], struct totals t, int size)
{
for (int i = 0; i < size; i++)
{
t.total_wageRate += e[i].wageRate;
t.total_hours += e[i].hours;
t.total_overtimeHrs += e[i].overtimeHrs;
t.total_grossPay += e[i].grossPay;
t.total_stateTax += e[i].stateTax;
t.total_fedTax += e[i].fedTax;
t.total_netPay += e[i].netPay;
}
return t;
}
struct min_max calcEmployeeMinMax(struct employee e[], struct min_max m, int size)
{
m.min_wageRate = m.max_wageRate = e[0].wageRate;
m.min_hours = m.max_hours = e[0].hours;
m.min_overtimeHrs = m.max_overtimeHrs = e[0].overtimeHrs;
m.min_grossPay = m.max_grossPay = e[0].grossPay;
m.min_stateTax = m.max_stateTax = e[0].stateTax;
m.min_fedTax = m.max_fedTax = e[0].fedTax;
m.min_netPay = m.max_netPay = e[0].netPay;
for (int i = 1; i < size; i++)
{
if (e[i].hours < m.min_hours) m.min_hours = e[i].hours;
if (e[i].hours > m.max_hours) m.max_hours = e[i].hours;
if (e[i].overtimeHrs < m.min_overtimeHrs) m.min_overtimeHrs = e[i].overtimeHrs;
if (e[i].overtimeHrs > m.max_overtimeHrs) m.max_overtimeHrs = e[i].overtimeHrs;
if (e[i].grossPay < m.min_grossPay) m.min_grossPay = e[i].grossPay;
if (e[i].grossPay > m.max_grossPay) m.max_grossPay = e[i].grossPay;
if (e[i].stateTax < m.min_stateTax) m.min_stateTax = e[i].stateTax;
if (e[i].stateTax > m.max_stateTax) m.max_stateTax = e[i].stateTax;
if (e[i].fedTax < m.min_fedTax) m.min_fedTax = e[i].fedTax;
if (e[i].fedTax > m.max_fedTax) m.max_fedTax = e[i].fedTax;
if (e[i].netPay < m.min_netPay) m.min_netPay = e[i].netPay;
if (e[i].netPay > m.max_netPay) m.max_netPay = e[i].netPay;
}
return m;
}
void printEmpStatistics(struct totals t, struct min_max m, int size)
{
printf("\n---------------------------------------------------------------------------------");
printf("\nTotals: %5.2f %5.1f %5.1f %7.2f %6.2f %7.2f %8.2f", t.total_wageRate, t.total_hours, t.total_overtimeHrs,
t.total_grossPay, t.total_stateTax, t.total_fedTax, t.total_netPay);
printf("\nAverages: %5.2f %5.1f %5.1f %7.2f %6.2f %7.2f %8.2f", t.total_wageRate/size, t.total_hours/size, t.total_overtimeHrs/size,
t.total_grossPay/size, t.total_stateTax/size, t.total_fedTax/size, t.total_netPay/size);
printf("\nMinimum: %5.2f %5.1f %5.1f %7.2f %6.2f %7.2f %8.2f", m.min_wageRate, m.min_hours, m.min_overtimeHrs,
m.min_grossPay, m.min_stateTax, m.min_fedTax, m.min_netPay);
printf("\nMaximum: %5.2f %5.1f %5.1f %7.2f %6.2f %7.2f %8.2f\n", m.max_wageRate, m.max_hours, m.max_overtimeHrs,
m.max_grossPay, m.max_stateTax, m.max_fedTax, m.max_netPay);
}
Ly8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgovLwovLyBBc3NpZ25tZW50IDcgLSBTdHJ1Y3R1cmVzIGFuZCBTdHJpbmdzCi8vCi8vIE5hbWU6IFlvdXIgTmFtZQovLyBDbGFzczogQyBQcm9ncmFtbWluZywgU3ByaW5nIDIwMjYKLy8gRGF0ZTogQ3VycmVudCBEYXRlCi8vCi8vKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCiNpbmNsdWRlIDxzdGRpby5oPgojaW5jbHVkZSA8c3RyaW5nLmg+CiNpbmNsdWRlIDxjdHlwZS5oPgoKI2RlZmluZSBTSVpFIDUKI2RlZmluZSBTVERfSE9VUlMgNDAuMAojZGVmaW5lIE9UX1JBVEUgMS41CiNkZWZpbmUgTUFfVEFYX1JBVEUgMC4wNQojZGVmaW5lIE5IX1RBWF9SQVRFIDAuMAojZGVmaW5lIFZUX1RBWF9SQVRFIDAuMDYKI2RlZmluZSBDQV9UQVhfUkFURSAwLjA3CiNkZWZpbmUgREVGQVVMVF9UQVhfUkFURSAwLjA4CiNkZWZpbmUgVEFYX1NUQVRFX1NJWkUgMwojZGVmaW5lIEZFRF9UQVhfUkFURSAwLjI1CiNkZWZpbmUgRklSU1RfTkFNRV9TSVpFIDEwCiNkZWZpbmUgTEFTVF9OQU1FX1NJWkUgMTAKCnN0cnVjdCBuYW1lCnsKICAgIGNoYXIgZmlyc3ROYW1lW0ZJUlNUX05BTUVfU0laRV07CiAgICBjaGFyIGxhc3ROYW1lW0xBU1RfTkFNRV9TSVpFXTsKfTsKCnN0cnVjdCBlbXBsb3llZQp7CiAgICBzdHJ1Y3QgbmFtZSBlbXBOYW1lOwogICAgY2hhciB0YXhTdGF0ZVtUQVhfU1RBVEVfU0laRV07CiAgICBsb25nIGludCBjbG9ja051bWJlcjsKICAgIGZsb2F0IHdhZ2VSYXRlOwogICAgZmxvYXQgaG91cnM7CiAgICBmbG9hdCBvdmVydGltZUhyczsKICAgIGZsb2F0IGdyb3NzUGF5OwogICAgZmxvYXQgc3RhdGVUYXg7CiAgICBmbG9hdCBmZWRUYXg7CiAgICBmbG9hdCBuZXRQYXk7Cn07CgpzdHJ1Y3QgdG90YWxzCnsKICAgIGZsb2F0IHRvdGFsX3dhZ2VSYXRlOwogICAgZmxvYXQgdG90YWxfaG91cnM7CiAgICBmbG9hdCB0b3RhbF9vdmVydGltZUhyczsKICAgIGZsb2F0IHRvdGFsX2dyb3NzUGF5OwogICAgZmxvYXQgdG90YWxfc3RhdGVUYXg7CiAgICBmbG9hdCB0b3RhbF9mZWRUYXg7CiAgICBmbG9hdCB0b3RhbF9uZXRQYXk7Cn07CgpzdHJ1Y3QgbWluX21heAp7CiAgICBmbG9hdCBtaW5fd2FnZVJhdGUsIG1pbl9ob3VycywgbWluX292ZXJ0aW1lSHJzLCBtaW5fZ3Jvc3NQYXksIG1pbl9zdGF0ZVRheCwgbWluX2ZlZFRheCwgbWluX25ldFBheTsKICAgIGZsb2F0IG1heF93YWdlUmF0ZSwgbWF4X2hvdXJzLCBtYXhfb3ZlcnRpbWVIcnMsIG1heF9ncm9zc1BheSwgbWF4X3N0YXRlVGF4LCBtYXhfZmVkVGF4LCBtYXhfbmV0UGF5Owp9OwoKLy8gZnVuY3Rpb24gcHJvdG90eXBlcwp2b2lkIGdldEhvdXJzKHN0cnVjdCBlbXBsb3llZVtdLCBpbnQpOwp2b2lkIGNhbGNPdmVydGltZUhycyhzdHJ1Y3QgZW1wbG95ZWVbXSwgaW50KTsKdm9pZCBjYWxjR3Jvc3NQYXkoc3RydWN0IGVtcGxveWVlW10sIGludCk7CnZvaWQgY2FsY1N0YXRlVGF4KHN0cnVjdCBlbXBsb3llZVtdLCBpbnQpOwp2b2lkIGNhbGNGZWRUYXgoc3RydWN0IGVtcGxveWVlW10sIGludCk7CnZvaWQgY2FsY05ldFBheShzdHJ1Y3QgZW1wbG95ZWVbXSwgaW50KTsKdm9pZCBwcmludEhlYWRlcih2b2lkKTsKdm9pZCBwcmludEVtcChzdHJ1Y3QgZW1wbG95ZWVbXSwgaW50KTsKc3RydWN0IHRvdGFscyBjYWxjRW1wbG95ZWVUb3RhbHMoc3RydWN0IGVtcGxveWVlW10sIHN0cnVjdCB0b3RhbHMsIGludCk7CnN0cnVjdCBtaW5fbWF4IGNhbGNFbXBsb3llZU1pbk1heChzdHJ1Y3QgZW1wbG95ZWVbXSwgc3RydWN0IG1pbl9tYXgsIGludCk7CnZvaWQgcHJpbnRFbXBTdGF0aXN0aWNzKHN0cnVjdCB0b3RhbHMsIHN0cnVjdCBtaW5fbWF4LCBpbnQpOwoKaW50IG1haW4oKQp7CiAgICBzdHJ1Y3QgZW1wbG95ZWUgZW1wbG95ZWVEYXRhW1NJWkVdID0gewogICAgICAgIHsgeyJDb25uaWUiLCAiQ29ib2wifSwgIk1BIiwgOTg0MDEsIDEwLjYwfSwKICAgICAgICB7IHsiTWFyeSIsICJBcGwifSwgIk5IIiwgNTI2NDg4LCA5Ljc1IH0sCiAgICAgICAgeyB7IkZyYW5rIiwgIkZvcnRyYW4ifSwgIlZUIiwgNzY1MzQ5LCAxMC41MCB9LAogICAgICAgIHsgeyJKZWZmIiwgIkFkYSJ9LCAiTlkiLCAzNDY0NSwgMTIuMjUgfSwKICAgICAgICB7IHsiQW50b24iLCAiUGFzY2FsIn0sIkNBIiwxMjc2MTUsIDguMzUgfQogICAgfTsKCiAgICBzdHJ1Y3QgdG90YWxzIGVtcGxveWVlVG90YWxzID0gezB9OwogICAgc3RydWN0IG1pbl9tYXggZW1wbG95ZWVNaW5NYXggPSB7MH07CgogICAgZ2V0SG91cnMoZW1wbG95ZWVEYXRhLCBTSVpFKTsKICAgIGNhbGNPdmVydGltZUhycyhlbXBsb3llZURhdGEsIFNJWkUpOwogICAgY2FsY0dyb3NzUGF5KGVtcGxveWVlRGF0YSwgU0laRSk7CiAgICBjYWxjU3RhdGVUYXgoZW1wbG95ZWVEYXRhLCBTSVpFKTsKICAgIGNhbGNGZWRUYXgoZW1wbG95ZWVEYXRhLCBTSVpFKTsKICAgIGNhbGNOZXRQYXkoZW1wbG95ZWVEYXRhLCBTSVpFKTsKCiAgICBlbXBsb3llZVRvdGFscyA9IGNhbGNFbXBsb3llZVRvdGFscyhlbXBsb3llZURhdGEsIGVtcGxveWVlVG90YWxzLCBTSVpFKTsKICAgIGVtcGxveWVlTWluTWF4ID0gY2FsY0VtcGxveWVlTWluTWF4KGVtcGxveWVlRGF0YSwgZW1wbG95ZWVNaW5NYXgsIFNJWkUpOwoKICAgIHByaW50SGVhZGVyKCk7CiAgICBwcmludEVtcChlbXBsb3llZURhdGEsIFNJWkUpOwogICAgcHJpbnRFbXBTdGF0aXN0aWNzKGVtcGxveWVlVG90YWxzLCBlbXBsb3llZU1pbk1heCwgU0laRSk7CgogICAgcmV0dXJuIDA7Cn0KCi8vLS0tLS0tLS0tLS0tLS0tLSBGVU5DVElPTlMgLS0tLS0tLS0tLS0tLS0tLS8vCgp2b2lkIGdldEhvdXJzKHN0cnVjdCBlbXBsb3llZSBlW10sIGludCBzaXplKQp7CiAgICBmb3IgKGludCBpID0gMDsgaSA8IHNpemU7IGkrKykKICAgIHsKICAgICAgICBwcmludGYoIlxuRW50ZXIgaG91cnMgd29ya2VkIGJ5IGVtcCAjICUwNmxpOiAiLCBlW2ldLmNsb2NrTnVtYmVyKTsKICAgICAgICBzY2FuZigiJWYiLCAmZVtpXS5ob3Vycyk7CiAgICB9Cn0KCnZvaWQgY2FsY092ZXJ0aW1lSHJzKHN0cnVjdCBlbXBsb3llZSBlW10sIGludCBzaXplKQp7CiAgICBmb3IgKGludCBpID0gMDsgaSA8IHNpemU7IGkrKykKICAgICAgICBlW2ldLm92ZXJ0aW1lSHJzID0gKGVbaV0uaG91cnMgPiBTVERfSE9VUlMpID8gKGVbaV0uaG91cnMgLSBTVERfSE9VUlMpIDogMDsKfQoKdm9pZCBjYWxjR3Jvc3NQYXkoc3RydWN0IGVtcGxveWVlIGVbXSwgaW50IHNpemUpCnsKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgc2l6ZTsgaSsrKQogICAgewogICAgICAgIGZsb2F0IG5vcm1hbCA9IChlW2ldLmhvdXJzIC0gZVtpXS5vdmVydGltZUhycykgKiBlW2ldLndhZ2VSYXRlOwogICAgICAgIGZsb2F0IG92ZXJ0aW1lID0gZVtpXS5vdmVydGltZUhycyAqIE9UX1JBVEUgKiBlW2ldLndhZ2VSYXRlOwogICAgICAgIGVbaV0uZ3Jvc3NQYXkgPSBub3JtYWwgKyBvdmVydGltZTsKICAgIH0KfQoKdm9pZCBjYWxjU3RhdGVUYXgoc3RydWN0IGVtcGxveWVlIGVbXSwgaW50IHNpemUpCnsKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgc2l6ZTsgaSsrKQogICAgewogICAgICAgIGlmIChzdHJjbXAoZVtpXS50YXhTdGF0ZSwgIk1BIikgPT0gMCkKICAgICAgICAgICAgZVtpXS5zdGF0ZVRheCA9IGVbaV0uZ3Jvc3NQYXkgKiBNQV9UQVhfUkFURTsKICAgICAgICBlbHNlIGlmIChzdHJjbXAoZVtpXS50YXhTdGF0ZSwgIk5IIikgPT0gMCkKICAgICAgICAgICAgZVtpXS5zdGF0ZVRheCA9IGVbaV0uZ3Jvc3NQYXkgKiBOSF9UQVhfUkFURTsKICAgICAgICBlbHNlIGlmIChzdHJjbXAoZVtpXS50YXhTdGF0ZSwgIlZUIikgPT0gMCkKICAgICAgICAgICAgZVtpXS5zdGF0ZVRheCA9IGVbaV0uZ3Jvc3NQYXkgKiBWVF9UQVhfUkFURTsKICAgICAgICBlbHNlIGlmIChzdHJjbXAoZVtpXS50YXhTdGF0ZSwgIkNBIikgPT0gMCkKICAgICAgICAgICAgZVtpXS5zdGF0ZVRheCA9IGVbaV0uZ3Jvc3NQYXkgKiBDQV9UQVhfUkFURTsKICAgICAgICBlbHNlCiAgICAgICAgICAgIGVbaV0uc3RhdGVUYXggPSBlW2ldLmdyb3NzUGF5ICogREVGQVVMVF9UQVhfUkFURTsKICAgIH0KfQoKdm9pZCBjYWxjRmVkVGF4KHN0cnVjdCBlbXBsb3llZSBlW10sIGludCBzaXplKQp7CiAgICBmb3IgKGludCBpID0gMDsgaSA8IHNpemU7IGkrKykKICAgICAgICBlW2ldLmZlZFRheCA9IGVbaV0uZ3Jvc3NQYXkgKiBGRURfVEFYX1JBVEU7Cn0KCnZvaWQgY2FsY05ldFBheShzdHJ1Y3QgZW1wbG95ZWUgZVtdLCBpbnQgc2l6ZSkKewogICAgZm9yIChpbnQgaSA9IDA7IGkgPCBzaXplOyBpKyspCiAgICAgICAgZVtpXS5uZXRQYXkgPSBlW2ldLmdyb3NzUGF5IC0gKGVbaV0uc3RhdGVUYXggKyBlW2ldLmZlZFRheCk7Cn0KCnZvaWQgcHJpbnRIZWFkZXIodm9pZCkKewogICAgcHJpbnRmKCJcblxuKioqIFBheSBDYWxjdWxhdG9yICoqKlxuIik7CiAgICBwcmludGYoIlxuLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tIik7CiAgICBwcmludGYoIlxuTmFtZSAgICAgICAgICAgICAgICBUYXggIENsb2NrIyAgV2FnZSAgIEhvdXJzICBPVCAgIEdyb3NzICAgU3RhdGUgIEZlZCAgICAgIE5ldCIpOwogICAgcHJpbnRmKCJcbiAgICAgICAgICAgICAgICAgICAgU3RhdGUgICAgICAgICAgICAgICAgICAgICAgICAgICBQYXkgICAgIFRheCAgICBUYXggICAgICBQYXkiKTsKICAgIHByaW50ZigiXG4tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0iKTsKfQoKdm9pZCBwcmludEVtcChzdHJ1Y3QgZW1wbG95ZWUgZVtdLCBpbnQgc2l6ZSkKewogICAgY2hhciBuYW1lWzI1XTsKCiAgICBmb3IgKGludCBpID0gMDsgaSA8IHNpemU7IGkrKykKICAgIHsKICAgICAgICBzdHJjcHkobmFtZSwgZVtpXS5lbXBOYW1lLmZpcnN0TmFtZSk7CiAgICAgICAgc3RyY2F0KG5hbWUsICIgIik7CiAgICAgICAgc3RyY2F0KG5hbWUsIGVbaV0uZW1wTmFtZS5sYXN0TmFtZSk7CgogICAgICAgIHByaW50ZigiXG4lLTIwcyAlLTJzICUwNmxpICU2LjJmICU2LjFmICU1LjFmICU3LjJmICU2LjJmICU3LjJmICU4LjJmIiwKICAgICAgICAgICAgbmFtZSwgZVtpXS50YXhTdGF0ZSwgZVtpXS5jbG9ja051bWJlciwKICAgICAgICAgICAgZVtpXS53YWdlUmF0ZSwgZVtpXS5ob3VycywgZVtpXS5vdmVydGltZUhycywKICAgICAgICAgICAgZVtpXS5ncm9zc1BheSwgZVtpXS5zdGF0ZVRheCwKICAgICAgICAgICAgZVtpXS5mZWRUYXgsIGVbaV0ubmV0UGF5KTsKICAgIH0KfQoKc3RydWN0IHRvdGFscyBjYWxjRW1wbG95ZWVUb3RhbHMoc3RydWN0IGVtcGxveWVlIGVbXSwgc3RydWN0IHRvdGFscyB0LCBpbnQgc2l6ZSkKewogICAgZm9yIChpbnQgaSA9IDA7IGkgPCBzaXplOyBpKyspCiAgICB7CiAgICAgICAgdC50b3RhbF93YWdlUmF0ZSArPSBlW2ldLndhZ2VSYXRlOwogICAgICAgIHQudG90YWxfaG91cnMgKz0gZVtpXS5ob3VyczsKICAgICAgICB0LnRvdGFsX292ZXJ0aW1lSHJzICs9IGVbaV0ub3ZlcnRpbWVIcnM7CiAgICAgICAgdC50b3RhbF9ncm9zc1BheSArPSBlW2ldLmdyb3NzUGF5OwogICAgICAgIHQudG90YWxfc3RhdGVUYXggKz0gZVtpXS5zdGF0ZVRheDsKICAgICAgICB0LnRvdGFsX2ZlZFRheCArPSBlW2ldLmZlZFRheDsKICAgICAgICB0LnRvdGFsX25ldFBheSArPSBlW2ldLm5ldFBheTsKICAgIH0KICAgIHJldHVybiB0Owp9CgpzdHJ1Y3QgbWluX21heCBjYWxjRW1wbG95ZWVNaW5NYXgoc3RydWN0IGVtcGxveWVlIGVbXSwgc3RydWN0IG1pbl9tYXggbSwgaW50IHNpemUpCnsKICAgIG0ubWluX3dhZ2VSYXRlID0gbS5tYXhfd2FnZVJhdGUgPSBlWzBdLndhZ2VSYXRlOwogICAgbS5taW5faG91cnMgPSBtLm1heF9ob3VycyA9IGVbMF0uaG91cnM7CiAgICBtLm1pbl9vdmVydGltZUhycyA9IG0ubWF4X292ZXJ0aW1lSHJzID0gZVswXS5vdmVydGltZUhyczsKICAgIG0ubWluX2dyb3NzUGF5ID0gbS5tYXhfZ3Jvc3NQYXkgPSBlWzBdLmdyb3NzUGF5OwogICAgbS5taW5fc3RhdGVUYXggPSBtLm1heF9zdGF0ZVRheCA9IGVbMF0uc3RhdGVUYXg7CiAgICBtLm1pbl9mZWRUYXggPSBtLm1heF9mZWRUYXggPSBlWzBdLmZlZFRheDsKICAgIG0ubWluX25ldFBheSA9IG0ubWF4X25ldFBheSA9IGVbMF0ubmV0UGF5OwoKICAgIGZvciAoaW50IGkgPSAxOyBpIDwgc2l6ZTsgaSsrKQogICAgewogICAgICAgIGlmIChlW2ldLmhvdXJzIDwgbS5taW5faG91cnMpIG0ubWluX2hvdXJzID0gZVtpXS5ob3VyczsKICAgICAgICBpZiAoZVtpXS5ob3VycyA+IG0ubWF4X2hvdXJzKSBtLm1heF9ob3VycyA9IGVbaV0uaG91cnM7CgogICAgICAgIGlmIChlW2ldLm92ZXJ0aW1lSHJzIDwgbS5taW5fb3ZlcnRpbWVIcnMpIG0ubWluX292ZXJ0aW1lSHJzID0gZVtpXS5vdmVydGltZUhyczsKICAgICAgICBpZiAoZVtpXS5vdmVydGltZUhycyA+IG0ubWF4X292ZXJ0aW1lSHJzKSBtLm1heF9vdmVydGltZUhycyA9IGVbaV0ub3ZlcnRpbWVIcnM7CgogICAgICAgIGlmIChlW2ldLmdyb3NzUGF5IDwgbS5taW5fZ3Jvc3NQYXkpIG0ubWluX2dyb3NzUGF5ID0gZVtpXS5ncm9zc1BheTsKICAgICAgICBpZiAoZVtpXS5ncm9zc1BheSA+IG0ubWF4X2dyb3NzUGF5KSBtLm1heF9ncm9zc1BheSA9IGVbaV0uZ3Jvc3NQYXk7CgogICAgICAgIGlmIChlW2ldLnN0YXRlVGF4IDwgbS5taW5fc3RhdGVUYXgpIG0ubWluX3N0YXRlVGF4ID0gZVtpXS5zdGF0ZVRheDsKICAgICAgICBpZiAoZVtpXS5zdGF0ZVRheCA+IG0ubWF4X3N0YXRlVGF4KSBtLm1heF9zdGF0ZVRheCA9IGVbaV0uc3RhdGVUYXg7CgogICAgICAgIGlmIChlW2ldLmZlZFRheCA8IG0ubWluX2ZlZFRheCkgbS5taW5fZmVkVGF4ID0gZVtpXS5mZWRUYXg7CiAgICAgICAgaWYgKGVbaV0uZmVkVGF4ID4gbS5tYXhfZmVkVGF4KSBtLm1heF9mZWRUYXggPSBlW2ldLmZlZFRheDsKCiAgICAgICAgaWYgKGVbaV0ubmV0UGF5IDwgbS5taW5fbmV0UGF5KSBtLm1pbl9uZXRQYXkgPSBlW2ldLm5ldFBheTsKICAgICAgICBpZiAoZVtpXS5uZXRQYXkgPiBtLm1heF9uZXRQYXkpIG0ubWF4X25ldFBheSA9IGVbaV0ubmV0UGF5OwogICAgfQoKICAgIHJldHVybiBtOwp9Cgp2b2lkIHByaW50RW1wU3RhdGlzdGljcyhzdHJ1Y3QgdG90YWxzIHQsIHN0cnVjdCBtaW5fbWF4IG0sIGludCBzaXplKQp7CiAgICBwcmludGYoIlxuLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tIik7CgogICAgcHJpbnRmKCJcblRvdGFsczogICAgICAgICAgICAgICAgICAgICAgICAgJTUuMmYgJTUuMWYgJTUuMWYgJTcuMmYgJTYuMmYgJTcuMmYgJTguMmYiLAogICAgICAgIHQudG90YWxfd2FnZVJhdGUsIHQudG90YWxfaG91cnMsIHQudG90YWxfb3ZlcnRpbWVIcnMsCiAgICAgICAgdC50b3RhbF9ncm9zc1BheSwgdC50b3RhbF9zdGF0ZVRheCwgdC50b3RhbF9mZWRUYXgsIHQudG90YWxfbmV0UGF5KTsKCiAgICBwcmludGYoIlxuQXZlcmFnZXM6ICAgICAgICAgICAgICAgICAgICAgICAlNS4yZiAlNS4xZiAlNS4xZiAlNy4yZiAlNi4yZiAlNy4yZiAlOC4yZiIsCiAgICAgICAgdC50b3RhbF93YWdlUmF0ZS9zaXplLCB0LnRvdGFsX2hvdXJzL3NpemUsIHQudG90YWxfb3ZlcnRpbWVIcnMvc2l6ZSwKICAgICAgICB0LnRvdGFsX2dyb3NzUGF5L3NpemUsIHQudG90YWxfc3RhdGVUYXgvc2l6ZSwgdC50b3RhbF9mZWRUYXgvc2l6ZSwgdC50b3RhbF9uZXRQYXkvc2l6ZSk7CgogICAgcHJpbnRmKCJcbk1pbmltdW06ICAgICAgICAgICAgICAgICAgICAgICAgJTUuMmYgJTUuMWYgJTUuMWYgJTcuMmYgJTYuMmYgJTcuMmYgJTguMmYiLAogICAgICAgIG0ubWluX3dhZ2VSYXRlLCBtLm1pbl9ob3VycywgbS5taW5fb3ZlcnRpbWVIcnMsCiAgICAgICAgbS5taW5fZ3Jvc3NQYXksIG0ubWluX3N0YXRlVGF4LCBtLm1pbl9mZWRUYXgsIG0ubWluX25ldFBheSk7CgogICAgcHJpbnRmKCJcbk1heGltdW06ICAgICAgICAgICAgICAgICAgICAgICAgJTUuMmYgJTUuMWYgJTUuMWYgJTcuMmYgJTYuMmYgJTcuMmYgJTguMmZcbiIsCiAgICAgICAgbS5tYXhfd2FnZVJhdGUsIG0ubWF4X2hvdXJzLCBtLm1heF9vdmVydGltZUhycywKICAgICAgICBtLm1heF9ncm9zc1BheSwgbS5tYXhfc3RhdGVUYXgsIG0ubWF4X2ZlZFRheCwgbS5tYXhfbmV0UGF5KTsKfQ==