Be sure you have read (or at least skimmed) the assigned readings from chapter 4, and section 9 (about recursion) from chapter 6.
Please include with each part of the assignment the Honor Code pledge or just the word ``pledged'', plus one or more of the following about collaboration and help (as many as apply).1Text in italics is explanatory or something for you to fill in. For written assignments, it should go right after your name and the assignment number; for programming assignments, it should go in comments at the start of your program.
Do the following programming problems. You will end up with at least one code file per problem. Submit your program source (and any other needed files) by sending mail to bmassing@cs.trinity.edu with each file as an attachment. Please use a subject line that mentions the course and the assignment (e.g., ``csci 1312 hw 4'' or ``CS1 hw 4''). You can develop your programs on any system that provides the needed functionality, but I will test them on one of the department's Linux machines, so you should probably make sure they work in that environment before turning them in.
double f_to_c(double f);where the single parameter f represents a Fahrenheit temperature and the return value represents the equivalent Celsius temperature. (So, for example, f_to_c(32.0) should evaluate to 0.0.0
void convert_and_print(double f);that calls the conversion function and prints its input and output nicely. So for example convert_and_print(32.0); might print
32 degrees Fahrenheit is 0 degrees Celsius(Don't worry too much about printing appropriate numbers of digits after the decimal point; you can do whatever is easy, or read the man page or other documentation for printf to find out how to get more control.)
NOTE that the point of this problem is for you to practice defining and using functions, so you will not get full credit unless your program includes functions as described.
 and
 and  , not both zero, and computes and prints
, not both zero, and computes and prints
 , the greatest common divisor of
, the greatest common divisor of  and
and  , using a recursive version of Euclid's algorithm.
Print an error message if what was entered is not two integers,
or either input is negative, or both are zero.
, using a recursive version of Euclid's algorithm.
Print an error message if what was entered is not two integers,
or either input is negative, or both are zero.
Euclid's algorithm can be described recursively thus:
For non-negative integers  and
 and  ,
not both zero, with
,
not both zero, with  ,
,
|  | 
 is the remainder when
 
is the remainder when  is divided by
 is divided by  .
(You don't actually have to understand this algorithm to turn it
into code, but if you want to and don't, a Web search will likely
turn up some good explanations of how/why it works.)
.
(You don't actually have to understand this algorithm to turn it
into code, but if you want to and don't, a Web search will likely
turn up some good explanations of how/why it works.)
NOTE that the point of this problem is for you to practice defining and using a recursive function, so you will not get full credit unless you do. I recommend putting all the error checking in the main program and having a recursive function declared as
int gcd(int a, int b);