用C语言编写一个程序,写一个可以返回栈S中节点个数的算法int StackSize(SeqStack S),其中S不能作为指针参数
时间: 2024-09-25 10:21:21 浏览: 35
在C语言中,由于C标准库并没有提供内置的栈数据结构,我们通常会自定义一个顺序栈(SeqStack)的数据结构,比如使用数组来实现。下面是一个简单的示例,展示了如何编写一个函数`StackSize`来计算栈中节点的数量。首先,我们需要一个栈结构体定义,并且因为函数需要访问栈的内部信息,所以这里假设栈的顶部元素索引是栈大小减一。
```c
#include <stdio.h>
// 自定义栈结构体(仅用于演示,实际应用可能更复杂)
typedef struct {
int capacity; // 栈容量
int top; // 当前栈顶元素索引
} SeqStack;
// 初始化栈
void InitStack(SeqStack *S, int capacity) {
S->capacity = capacity;
S->top = -1;
}
// 判断栈是否为空
int IsEmpty(SeqStack S) {
return S.top == -1;
}
// 返回栈中的节点个数(不包括空栈)
int StackSize(SeqStack S) {
return (S.top + 1); // 加1是因为0表示栈为空
}
int main() {
SeqStack stack;
InitStack(&stack, 5);
// ... 其他操作 ...
int size = StackSize(stack);
printf("栈中的节点个数: %d\n", size);
return 0;
}
```
在这个例子中,`StackSize`函数直接从栈的顶部索引获取栈中元素的数量。注意,由于C语言中数组下标是从0开始的,所以当`top`为`-1`时代表栈为空。如果实际应用中栈顶部元素的索引需要其他处理,可以根据需求修改这个函数。
阅读全文