首先我们分析由于只需要尾进尾出,用数组模拟更简单。
data:image/s3,"s3://crabby-images/53b5d/53b5dbf620e62bcf48daaa2dd60eef1cc0bdc368" alt=""
实现的功能如上图。
top可以表示栈中元素个数。
capacity表示栈的容量。
首先是堆的初始化
data:image/s3,"s3://crabby-images/ebdb9/ebdb9c1353b630922976e187511922dde24449b2" alt=""
再就是栈的插入和删除
data:image/s3,"s3://crabby-images/ff55e/ff55ed2b47fae2bd78f74a9661d48f22739de68d" alt=""
data:image/s3,"s3://crabby-images/28e8f/28e8fbe429bb03601ea91e6bd282b0e1dd4fa35f" alt=""
然后实现显示栈顶元素
data:image/s3,"s3://crabby-images/f027d/f027dda9e269e354e075b71986ed6528b2c3e9e4" alt=""
大小和检测是否为空的实现
data:image/s3,"s3://crabby-images/f0c8b/f0c8b19fe0b750969cdd4530e6b7880bceaddaa3" alt=""
销毁栈的实现(防止内存泄露)
data:image/s3,"s3://crabby-images/92b11/92b113d7619588cd4a73e1296a5dd90622e6dd65" alt=""
下面是队列的实现
由于需要头出尾入,所有用链表实现更好。
data:image/s3,"s3://crabby-images/f5a84/f5a84cab9e90a4e407370a1e65f2c64d7528e4a8" alt=""
data:image/s3,"s3://crabby-images/c95b6/c95b63d34afbf090ac6eed54595679a0409f11d9" alt=""
为了避免每一次调用的时候还要输入头,尾指针,直接进行打包成结构体。
初始化的实现
data:image/s3,"s3://crabby-images/198d8/198d8096f8d85b6377cb4f9705992178f70cc2c1" alt=""
尾插的实现。
data:image/s3,"s3://crabby-images/92e98/92e983ae41753b691862543ff5b47948c3080439" alt=""
尾删的实现。
data:image/s3,"s3://crabby-images/bea24/bea24e1872c9352f36323d679be1da1462c44e08" alt=""
整个队列销毁的实现
data:image/s3,"s3://crabby-images/85b02/85b0209b9232fc70536e2fe5487ca947ee4fee69" alt=""
然后我们就要实现队列的头显和尾显已经判断是否为空的实现。
data:image/s3,"s3://crabby-images/ca969/ca96918b6e66261eaf556be81b58f0aced908caf" alt=""
最后就是判断队列大小的实现。
data:image/s3,"s3://crabby-images/6749e/6749ec3bd5d7580decb49dd4f3d3d12c8d0f890a" alt=""