I\'m learning C from K&R\'s \"The C Programming Language\" book. I\'m doing the exercises specified in the book. I\'m on exercise number 1.16, but I don\'t understand it
It's a pretty early exercise in K&R, you're just supposed to do some minor changes to the code, not a total redesign of the code.
"...as much as possible of the text..."
is up to you to interpret. I'd do it by printing what's stored in the longest
buffer. i.e. print out up to 1000 characters of the line. Again, it's an early exercise, with little introduction to dynamically allocated memory yet. And at the time K&R was written, storing away arbitrarily long text lines wasn't as feasible as it is today.
"...the length of arbitrarily long input lines..."
Is a hard requirement. You're supposed to find the correct length no matter how long it is (at least within the bounds of an int
. )
One way to solve this problem is:
line
buffer is a newline ('\n')len
variable is the correct length of the line(the return value of getline(), and no special consideration is needed compared to to original code.len++
to count.len
is now the actual length of the line, but our buffer just has the first 999 characters of it.line
buffer (max 1000 chars) if this line is the longest so far.longest
buffer) and the max
variable for the length.
max
length is now correct.longest
line indeed was longer than 1000 chars. you at least print out those first 999 chars - which is "as much as possible".I'll not spoil it and post the code you need to accomplish this, but it is just 6 lines of code that you need to add to the longest-line program of exercise 1-16.