Assignment 4 - Makefiles and Function Pointers: The Problems of This Assignment Must Be Solved in C

Download as pdf or txt
Download as pdf or txt
You are on page 1of 3

Programming in C II, Module II Course: JTSK-320112

Jacobs University Bremen March 11th , 2016


Dr. Kinga Lipskoch

Assignment 4 - Makefiles and Function Pointers

The problems of this assignment must be solved in C.


Your programs should have the input and output formatting according to the testcases
listed after the problems.

Your programs should consider the grading rules:


http://cantaloupe.eecs.jacobs-university.de/courses/320112/2016 1m1/Grading-Criteria-
C2.pdf

Problem 4.1 Makefile (2 points)


Presence assignment, due by 18:30 h today
Continue with your solution for Problem 3.4 in the following manner: write and upload a make-
file called Makefile.txt which has multiple targets and can be used to: 1) generate all object files
corresponding to the previous source files, 2) generate executable code from the object files and
3) delete all generated object files and the executable.
Submit the three source files and the makefile called Makefile.txt.
You can assume that the input will be valid.

Problem 4.2 Simple function pointers (2 points)


Write a program that reads a string and then repeatedly reads a command (one character) from
the standard input.
If you press 1, then the string is printed uppercase on the standard output.
If you press 2, then the string is printed lowercase on the standard output.
If you press 3, then lowercase characters are printed uppercase and uppercase characters are
printed lowercase on the standard output.
If you press 4, then the program should quit the execution.
Your main function (where you read the commands) or your other functions may not contain
any if or switch statements for mapping the command to which function should be called.
Your main function should contain an endless while loop.
Implement the solution using function pointers. The original string should not be changed.
You can assume that the input will be valid.

Testcase 4.2: input Testcase 4.2: output


This is a String THIS IS A STRING
1 this is a string
2 tHIS IS A sTRING
3 this is a string
2 THIS IS A STRING
1
4

Problem 4.3 Quicksort with function pointers (2 points)


Write a program that sorts an array of n integers. After reading n and the values of the array
from the standard input, the program reads a character and if this character is a then the sorting
should be ascending, if the character is d then the sorting should be descending and if the
character is e then the program should quit execution.
Your main() function should contain an endless while loop for getting repeated input.
Your program should use function pointers and for sorting you should use the function qsort()
from stdlib.h.
You can assume that the input will be valid.
Testcase 4.3: input Testcase 4.3: output
5 5 4 3 2 1
2 1 2 3 4 5
4
1
5
3
d
a
e

Problem 4.4 Bubblesort with function pointers (4 points)


Write a program that reads an array of the following structure and sorts the data in ascending
order by name or age using the bubblesort algorithm.
struct person {
char name[20];
int age;
};
Your program should read the number of persons from the standard input followed by the array
of data corresponding to the persons. You should print the lists of sorted persons in ascending
order with respect to their name (alphabetical order) and with respect to their age. Within the
sorting according to age, note that if multiple persons have the same age, then they should be
sorted alphabetically with respect to their name. Within the sorting according to name, note that
if multiple persons have the same name, then they should be sorted with respect to their age.
Instead of writing two sorting functions use function pointers such that you can implement one
bubblesort function able to sort according to different criteria.
You can assume that the input will be valid and that the names will not contain spaces.
The pseudocode of the bubblesort algorithm is the following:
repeat
swapped = false
for i = 1 to length(A) - 1 inclusive do:
/ if this pair is out of order /
if A[i-1] > A[i] then
/ swap them and remember something changed
/
swap( A[i-1], A[i] )
swapped = true
end if
end for
until not swapped

Testcase 4.4: input Testcase 4.4: output


3 {anne, 23}; {bob, 20}; {mary, 18};
anne {mary, 18}; {bob, 20}; {anne, 23};
23
mary
18
bob
20
How to submit your solutions
Your source code should be properly indented and compile with gcc without any warnings (You
can use gcc -Wall -o program program.c). Insert suitable comments (not on every line . . . ) to
explain what your program does.
Please name the programs according to the suggested filenames (they should match the description
of the problem) in Grader. Otherwise you might have problems with the inclusion of header files.
Each program must include a comment on the top like the following:
/*
JTSK-320112
a4 p1.c
Firstname Lastname
[email protected]
*/

You have to submit your solutions via Grader at


https://cantaloupe.eecs.jacobs-university.de.
If there are problems (but only then) you can submit the programs by sending mail to
[email protected] with a subject line that begins with JTSK-320112.
It is important that you do begin your subject with the coursenumber, otherwise I might have
problems to identify your submission.
Please note, that after the deadline it will not be possible to submit any solutions. It is useless to send
late solutions by mail, because they will not be accepted.

This assignment is due by Wednesday, March 16th , 10:00 h.

You might also like