栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

数据结构作业(栈)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

数据结构作业(栈)

栈:栈是限定仅在表尾进行插入或删除的线性表。因此,对栈来说,表尾端有其特殊含义,称为栈顶,相应地,表头端称为栈底。不含元素的空表称为空栈。栈的修改是按后进先出的原则进行的,因此,栈又称为后进先出的线性表。

创建栈:

typedef struct CharStack {
    int top;
 
    int data[STACK_MAX_SIZE]; 
} *CharStackPtr;

栈的初始化:

CharStackPtr charStackInit() {
	CharStackPtr resultPtr = (CharStackPtr)malloc(sizeof(CharStackPtr));  //申请内存 
	resultPtr->top = -1;
 
	return resultPtr;

打印栈:

void outputStack(CharStackPtr paraStack) {
	int i; 
    for (i = 0; i <= paraStack->top; i ++) {
        printf("%c ", paraStack->data[i]);
    }
    printf("rn");

入栈:实际为从栈底开始,每传入一个元素,top指针向上指向上一位,直至max

void push(CharStackPtr paraStackPtr, int paraValue) {
    
    if (paraStackPtr->top >= STACK_MAX_SIZE - 1) {
        printf("栈空间已满,不能入栈rn");
        return;
    }
 
  
	paraStackPtr->top ++;
 
	
    paraStackPtr->data[paraStackPtr->top] = paraValue;
}

出栈:

char pop(CharStackPtr paraStackPtr) {
   
    if (paraStackPtr->top < 0) {
        printf("都没了,无法出栈rn");
        return '';
    }
 
    
	paraStackPtr->top --;
 
	
    return paraStackPtr->data[paraStackPtr->top + 1];
}

测试:

void pushPopTest() {
	int i;
	char ch;
    printf("---- 弹压测试开始 ----rn");
 
	// 初始化 
    CharStackPtr tempStack = charStackInit();
    printf("初始化过后,这个栈是:");
	outputStack(tempStack);
 
	// 入栈 
	for (ch = 'a'; ch < 'm'; ch ++) {
		printf("入栈: %c.rn", ch);
		push(tempStack, ch);
		outputStack(tempStack);
	}
 
	// 出栈 
	for (i = 0; i < 3; i ++) {
		ch = pop(tempStack);
		printf("出栈: %c.rn", ch);
		outputStack(tempStack);
	}
 
    printf("---- 测试结束 ----rn");
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/873079.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号