Please use C Language Design a Stack structure.
Please use C Language
- Design a Stack structure.
-
Define push and pop functions for your Stack implementation.
-
Create a Memory structure owns number of block, block size, and stack attributes. You can add more attributes if it eases your implemen- tations.
Stack attribute represents memory blocks. Number of block attribute rep- resents the length of the stack. Block size represents the maximum value that each element in the stack can get.
-
Write an allocate function that takes a size parameter. If the given size is bigger than block size of the Memory, the allocation will be distributed to the different blocks in the stack attribute.
For example, calling allocate(27) updates the stack as allocate(27) = [10, 10, 7, 0, 0]
for a Memory with number of block = 5, block size = 10. The remaining of the elements which don’t have maximum value can be sealed until the element is flushed. Therefore, the next allocation can start from next element position after 7 given above.
-
Write an deallocate function that flushes the last used block.
Step by step
Solved in 3 steps