数据结构-堆栈

#include <stdio.h>
#include <stdlib.h>
/node/
typedef struct Node {
int data;
struct Node* pNext;
}NODE,*PNODE;

typedef struct Stack {
PNODE pTop;//栈顶
PNODE pBottom;//栈底部
}STACK,*PSTACK;

PNODE initStack(PSTACK pS)
{
PNODE pHead;
pHead = (PNODE)malloc(sizeof(NODE));
if(pHead == NULL)
printf(“malloc pS fail\n”);
pS->pTop = pHead;
pS->pBottom = pHead;
pS->pBottom->pNext = NULL;
return pHead;
}

void pushStack(PSTACK pS, int val)
{
PNODE pNew;
pNew = (PNODE)malloc(sizeof(NODE));
if(pNew == NULL)
printf(“malloc pNew fail\n”);
pNew->data = val;
//pS->pTop->pNext = pNew;//这个是关键 起到链接的作用 这个不行 针往上指了不便于遍历
pNew->pNext = pS->pTop;
pS->pTop = pNew;
}
void traverse(PSTACK pS)
{
PNODE pMov = pS->pTop;
/* while(pS->pTop->pNext != NULL){不能移动pTop的指向 它永远指向栈顶
pS->pTop = pS->pTop->pNext;
printf("%d",pS->pTop->data);
} */
while(pMov != pS->pBottom) {
printf("%d",pMov->data);
pMov = pMov->pNext;
}
printf("\n");
}
int pop_stack(PSTACK pS)
{
free(pS->pTop);
pS->pTop = pS->pTop->pNext;
}

int main(void)
{
STACK S;
initStack(&S);
pushStack(&S,4);
//pushStack(&S,2);
printf(“pTop->data = %d\n”,S.pTop->data);
pushStack(&S,2);
printf(“pTop->data = %d\n”,S.pTop->data);
traverse(&S);
pop_stack(&S);
traverse(&S);
return 0;
}
/*为什么pop_stack和pushStack的pS是同一个吗
答:是同一个因为传递的地址是一样的,也就是操作的内存区域是一样,相当于指针的copy
&S也是一个指针
initStack(&S); --------->PNODE initStack(PSTACK pS)
pushStack(&S,4);-------->void pushStack(PSTACK pS, int val)
操作的都是一个内存这个内存保存在堆区 这个两个pS可以理解为是同一个pS;函数执行完之后这个指针变量被释放掉了但是他指向的内存还在。
&S *pS 数组名 函数名都是指针
*/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值