158. Read N Characters Given Read4 II - Call multiple times
Problem description:
The API: int read4(char *buf) reads 4 characters at a time from a file.
The return value is the actual number of characters read. For example, it returns 3 if there is only 3 characters left in the file.
By using the read4 API, implement the function int read(char *buf, int n) that reads n characters from the file.
Note:
The read function may be called multiple times.
Example 1:
Given buf = “abc”
read(“abc”, 1) // returns “a”
read(“abc”, 2); // returns “bc”
read(“abc”, 1); // returns “”
Example 2:
Given buf = “abc”
read(“abc”, 4) // returns “abc”
read(“abc”, 1); // returns “”
Solution:
Use two variable, readPos and writePos to store the position of read and write. Scanning from 0…n, if the position of read and write are equal, the call read4
and give the return value to writePos because it’s the number characters read from input buffer. One thing to notice is that, if writePos == 0
, it means input buffer is empty, we should return current location i
.
1 | // Forward declaration of the read4 API. |
Another solution:
1 | // Forward declaration of the read4 API. |
time complexity: $O()$
space complexity: $O()$
reference: