Code

#include <stdio.h>

typedef struct {
    int buffer[10];
    int head;
    int tail;
    int count;
    int capacity;
} CircularBuffer;

void read_bytes(CircularBuffer *cb, int n) {
    for (int i = 0; i < n; i++) {
        // Kiểm tra xem trong kho còn hàng không
        if (cb->count > 0) {
            // Còn hàng -> In số và cập nhật tail
            printf("%d", cb->buffer[cb->tail]);
            
            // Cập nhật vị trí tail (xoay vòng)
            cb->tail = (cb->tail + 1) % (cb->capacity);
            cb->count--;
        } else {
            // Hết hàng -> In NULL theo yêu cầu đề bài
            printf("NULL");
        }

        // Logic xử lý dấu cách: Chỉ in dấu cách nếu chưa phải là phần tử cuối cùng
        if (i < n - 1) {
            printf(" ");
        }
    }

    // Xuống dòng sau khi in xong dãy số/NULL
    printf("\n");
    
    // In giá trị Tail cuối cùng
    printf("Tail: %d", cb->tail); 
}

int main() {
    CircularBuffer cb = {
        .buffer = {10, 20, 30, 40, 50, 60, 70, 80, 90, 100},
        .head = 3,
        .tail = 7,
        .count = 6,
        .capacity = 10
    };

    int n;
    // Lưu ý: scanf cần kiểm tra kết quả để an toàn hơn, nhưng với bài tập thì ok
    if (scanf("%d", &n) == 1) {
        read_bytes(&cb, n);
    }

    return 0;
}

Solving Approach

 

 

 

Upvote
Downvote
Loading...

Input

4

Expected Output

80 90 100 10 Tail: 1