1
0
mirror of https://github.com/krislamo/knrc.git synced 2025-01-07 03:50:36 +00:00
Examples and exercises from second edition K&R
Go to file
2021-11-23 00:31:57 -05:00
bin Compile simple stdout message 2021-11-03 00:02:07 -04:00
01-hello-world.c Compile simple stdout message 2021-11-03 00:02:07 -04:00
02-vars-and-math.c Don't bury magic numbers! 2021-11-05 20:42:05 -04:00
03-celsius-to-fahrenheit.c Don't bury magic numbers! 2021-11-05 20:42:05 -04:00
04-file-copying.c Exercise 1-6 and 1-7. expression = 1, and EOF = -1 2021-11-05 21:17:39 -04:00
05-char-counting.c Character counting example v2 2021-11-09 00:20:01 -05:00
06-line-count.c Exercise 1-8. count blanks, tabs, and newlines 2021-11-09 00:51:39 -05:00
07-extra-blanks.c Exercise 1-9. Replace multiple blanks with one 2021-11-11 23:04:06 -05:00
08-unambiguous.c Exercise 1-10. replace with escape codes 2021-11-11 23:30:43 -05:00
09-word-count.c Word counting example 2021-11-12 22:58:29 -05:00
10-one-word-per-line.c Exercise 1-12. one word per line 2021-11-13 00:30:40 -05:00
11-arrays.c Arrays example 2021-11-14 21:02:09 -05:00
12-histogram.c Exercise 1-13. Vertical histogram 2021-11-20 02:40:30 -05:00
13-functions.c Function example 2021-11-23 00:31:57 -05:00
Makefile Simplify Makefile to compile all C sources 2021-11-12 21:02:45 -05:00
README.adoc Exercise 1-11. test the word count program 2021-11-12 23:55:56 -05:00

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

Notes on K&R C (2nd edition)
----------------------------
This repository contains examples and exercises from the
https://en.wikipedia.org/wiki/The_C_Programming_Language[second edition K&R.]

- Compiled using gcc version 8.3.0 on Debian 10 x86_64

01-hello-world.c
~~~~~~~~~~~~~~~~
https://github.com/krislamo/knrc/commit/3e078042a42fed15b4de1b8ff31834f952ef5d81[(Diff)]
https://github.com/krislamo/knrc/blob/3e078042a42fed15b4de1b8ff31834f952ef5d81/01-hello-world.c[(Source)]

- A return type is explicitly set on the main function to clear a `gcc` warning in a slight deviation
from the book.

This example demonstrates an understanding of how to compile source code
to machine code. It includes the `01-hello-world.c` source file and a `Makefile` that
executes a `gcc` command to compile. In addition, a `.gitignore` file is included in
the `./bin` directory to keep binary artifacts out of version control.

Exercise 1-1: leave out parts
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
While these omissions are not directly included in the source, here are some examples of
leaving parts out to generate compilation errors or warnings.

Removing braces:

----
$ sed -i 's/[{}]//g' 01-hello-world.c
$ make
gcc -o ./bin/01-helloworld 01-hello-world.c
01-hello-world.c: In function main:
01-hello-world.c:5:2: error: expected declaration specifiers before printf
  printf("hello, world\n");
  ^~~~~~
01-hello-world.c:6: error: expected { at end of input


make: *** [Makefile:4: hello] Error 1
----

Removing the semicolon:

----
$ sed -i 's/[;]//g' 01-hello-world.c
$ make
gcc -o ./bin/01-helloworld 01-hello-world.c
01-hello-world.c: In function main:
01-hello-world.c:5:26: error: expected ; before } token
  printf("hello, world\n")
                          ^
                          ;
 }
 ~
make: *** [Makefile:4: hello] Error 1
----

Removing the include directive:

----
$ sed -i 's/#include.*//g' 01-hello-world.c
$ make
gcc -o ./bin/01-helloworld 01-hello-world.c
01-hello-world.c: In function main:
01-hello-world.c:5:2: warning: implicit declaration of function printf [-Wimplicit-function-declaration]
  printf("hello, world\n");
  ^~~~~~
01-hello-world.c:5:2: warning: incompatible implicit declaration of built-in function printf
01-hello-world.c:5:2: note: include <stdio.h> or provide a declaration of printf
01-hello-world.c:1:1:
+#include <stdio.h>

01-hello-world.c:5:2:
  printf("hello, world\n");
  ^~~~~~
$ ./bin/01-helloworld
hello, world
$
----

Exercise 1-2: unknown escapes in printf
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Adding a `\k` into printf:

----
$ sed -i 's/\\n/\\k\\n/g' 01-hello-world.c
$ make
gcc -o ./bin/01-helloworld 01-hello-world.c
01-hello-world.c: In function main:
01-hello-world.c:5:9: warning: unknown escape sequence: '\k'
  printf("hello, world\k\n");
         ^~~~~~~~~~~~~~~~~~
$ ./bin/01-helloworld
hello, worldk
$
----

02-vars-and-math.c
~~~~~~~~~~~~~~~~~~
https://github.com/krislamo/knrc/commit/9a193d84f112aa2bdfccc6c5137ce95aeccb1ead[(Diff)]
https://github.com/krislamo/knrc/blob/9a193d84f112aa2bdfccc6c5137ce95aeccb1ead/02-vars-and-math.c[(Source)]

This example incorporates comments, declaring variables, variable assignments, the
while loop, and displaying arithmetic results into stdout.

Higher precision
^^^^^^^^^^^^^^^^^
https://github.com/krislamo/knrc/commit/e7e2367bd7342302de7befacd90761671ebfe0bf[(Diff)]
https://github.com/krislamo/knrc/blob/e7e2367bd7342302de7befacd90761671ebfe0bf/02-vars-and-math.c[(Source)]

After typing out the second program's source, I instantly noticed a lack of floating-point
numbers (from previous knowledge). So, impatiently, I came up with a solution for a cleaner
and higher precision conversion table before seeing the book's answer. This slight change
involved changing the variables' type to `float` and changing `%d` to `%g` in printf.

Match textbook formatting
^^^^^^^^^^^^^^^^^^^^^^^^^
https://github.com/krislamo/knrc/commit/0d48636cdcdd5bc47e30fa6de21a1b8dcab7ec32[(Diff)]
https://github.com/krislamo/knrc/blob/0d48636cdcdd5bc47e30fa6de21a1b8dcab7ec32/02-vars-and-math.c[(Source)]

Conform to the textbook example, using better formatting and floating-point numbers
throughout the equation.

The for loop
^^^^^^^^^^^^
https://github.com/krislamo/knrc/commit/8ba629852ea914d74a28d0410e8a14aaf9724981[(Diff)]
https://github.com/krislamo/knrc/blob/8ba629852ea914d74a28d0410e8a14aaf9724981/02-vars-and-math.c[(Source)]

- I skipped over exercises 1-3 and 1-4 into the for loop in a slip-up

Here we simplify the code into a for loop, removing all but one variable.

Exercise 1-3: print a heading
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
https://github.com/krislamo/knrc/commit/0893987235ce02329c87ea000fb97eb0688bea54[(Diff)]
https://github.com/krislamo/knrc/blob/0893987235ce02329c87ea000fb97eb0688bea54/02-vars-and-math.c[(Source)]

I add a heading above the table with an additional printf statement and made a slight adjustment in
the original printf to align it better.

Exercise 1-4. print Celsius to Fahrenheit table
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
https://github.com/krislamo/knrc/commit/93126a8207ba83e3712bbab7b1e54548761a5fa1[(Diff)]
https://github.com/krislamo/knrc/blob/93126a8207ba83e3712bbab7b1e54548761a5fa1/03-celsius-to-fahrenheit.c[(Source)]

This is a simple little solution for a Celsius to Fahrenheit table.

Exercise 1-5. print the table in reverse order
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
https://github.com/krislamo/knrc/commit/588969b09fabab1e91ff4f4b1c37e87fc23cf76b[(Diff)]
https://github.com/krislamo/knrc/blob/588969b09fabab1e91ff4f4b1c37e87fc23cf76b/02-vars-and-math.c[(Source)]

Move some numbers around to reverse the table.

09-word-count.c
~~~~~~~~~~~~~~~~
https://github.com/krislamo/knrc/commit/d064db2b171e3da74fd5082ae29456f64caeafeb[(Diff)]
https://github.com/krislamo/knrc/blob/d064db2b171e3da74fd5082ae29456f64caeafeb/09-word-count.c[(Source)]

Textbook example of counting lines, words, and characters from input.

Exercise 1-11: test the word count program
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

No input:

----
$ ./bin/09-word-count
0 0 0
$
----

Just 3 newlines:

----
$ ./bin/09-word-count



3 0 3
$
----

Just 3 tabs:

----
$ ./bin/09-word-count
                        0 0 3
$
----

Just 3 spaces:

----
$ ./bin/09-word-count
   0 0 3
$
----

Just a single word per line:

----
$ ./bin/09-word-count
one
word
per
line
4 4 18
$
----

Three blanks before and after:

----
$ ./bin/09-word-count
   three blanks before/after   0 3 31
$
----