#include <stdio.h> #include <stdlib.h>
/*
- This stores the total number of books in each shelf. / int total_number_of_books;
/*
-
This stores the total number of pages in each book of each shelf.
-
The rows represent the shelves and the columns represent the books. / int* total_number_of_pages; int main() { int total_number_of_shelves; scanf("%d", &total_number_of_shelves);
int total_number_of_queries; scanf("%d", &total_number_of_queries);
total_number_of_books = (int *)malloc(sizeof(int)*total_number_of_shelves); total_number_of_pages = (int **)malloc(sizeof(int *)*total_number_of_shelves); for(int i = 0; i<total_number_of_shelves; i++){ (total_number_of_books + i) = 0; } while(total_number_of_queries--){ int type_of_query; scanf("%d", &type_of_query); if(type_of_query == 1){ int x, y; scanf("%d %d", &x, &y); int booksInShelf = (total_number_of_books + x); (total_number_of_pages + x) = (int)realloc((total_number_of_pages+x),sizeof(int)(booksInShelf+1)); ((total_number_of_pages+x)+booksInShelf) = y; *(total_number_of_books + x) += 1;
} else if (type_of_query == 2) { int x, y; scanf("%d %d", &x, &y); printf("%d\n", *(*(total_number_of_pages + x) + y)); } else { int x; scanf("%d", &x); printf("%d\n", *(total_number_of_books + x)); }
}
if (total_number_of_books) { free(total_number_of_books); }
for (int i = 0; i < total_number_of_shelves; i++) { if ((total_number_of_pages + i)) { free((total_number_of_pages + i)); } }
if (total_number_of_pages) { free(total_number_of_pages); }
return 0; }