Question: Part I 30 points 1. (10 point) Design a Stack structure. 2. (20 point) Define push and pop functions for your Stack implementation. Part II

 Part I 30 points 1. (10 point) Design a Stack structure.

Part I 30 points 1. (10 point) Design a Stack structure. 2. (20 point) Define push and pop functions for your Stack implementation. Part II 70 points 3. (10 point) 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. 4. (40 point) 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. 5. (20 point) Write an deallocate function that flushes the last used block. Note: Ensure that your programs are fully documented, using com- ments

Step by Step Solution

There are 3 Steps involved in it

1 Expert Approved Answer
Step: 1 Unlock blur-text-image
Question Has Been Solved by an Expert!

Get step-by-step solutions from verified subject matter experts

Step: 2 Unlock
Step: 3 Unlock

Students Have Also Explored These Related Databases Questions!