CSCI 1120 (Low-Level Computing), Spring 2014:
Homework 2
- Credit:
- 10 points.
Be sure you have read the assigned readings for classes through 2/12.
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 number and
the assignment (e.g., ``csci 1120 homework 2'').
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.
- (5 points)
Write a C program that asks the user for three integers and prints them
in order from smallest to largest, or an error message if what was
entered is something other than three integers.
(You may recognize this problem as a special case of one
you probably spent some time on in CS1.
Don't try to solve that problem in general for this assignment;
just solve the ``three numbers'' problem using what we've discussed
in class so far.)
Clarification:
Notice that the numbers do not have to be distinct -- for example,
the user could enter three values of 0.
- (5 points)
Write a C program that asks the user for two non-negative integers,
call them
and
, not both zero, and computes and prints
, the greatest common divisor of
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.
Euclid's algorithm can be described recursively thus:
For non-negative integers
and
,
not both zero, with
,
where
is the remainder when
is divided by
.
Berna Massingill
2014-02-19