41深入理解C指针之---指针与栈
一、借助第40指针与链表的相关内容,稍微修改即可:
1、定义头文件stack.h代码如下:
#include <stdlib.h>
#include <stdio.h> #ifndef stack_h
#define stack_h
typedef int DataType; typedef struct _node{
DataType data;
struct _node *next;
} Node; typedef struct _stack{
Node *head;
Node *tail;
} Stack; void initStack(Stack *);
void pushStack(Stack *, DataType);
void popStack(Stack *);
int getLength(Stack *);
void dispStack(Stack *); #endif
头文件中依旧是完成数据类型的声明和数据的操作函数的声明。
2、头文件对应的实现文件stack.c代码如下:
#include "stack.h" //栈初始化
void initStack(Stack *stack){
stack->head = NULL;
stack->tail = NULL;
} //栈入
void pushStack(Stack *stack, DataType iData){
Node *node = (Node *)malloc(sizeof(Node));
node->data = iData;
node->next = NULL; if(stack->head == NULL){
stack->tail = node;
}else{
node->next = stack->head;
}
stack->head = node; return; } //栈出
void popStack(Stack *stack){
if(stack->head->next == NULL){
stack->head = NULL;;
}else{
stack->head = stack->head->next;
} return;
} //栈长度
int getLength(Stack *stack){
Node *node = stack->head;
int i = ;
while(node != NULL){
node = node->next;
i++;
} return i;
} //栈输出
void dispStack(Stack *stack){
Node *node = stack->head;
int i = ;
while(node != NULL){
printf("the %dth node: %d\n", i + , node->data);
node = node->next;
i++;
}
printf("disp finished!\n"); return;
}
代码说明:
1、入栈函数使用链表的头插法
2、出栈函数直接将链表的头节点删除即可实现出栈功能
3、stack.c对应的测试文件testStack.c代码如下:
#include "stack.h" int main(int argc, char **argv)
{
Stack *stack1 = (Stack *)malloc(sizeof(Stack));
printf("the first:\n");
initStack(stack1);
pushStack(stack1, );
pushStack(stack1, );
pushStack(stack1, );
pushStack(stack1, );
pushStack(stack1, );
printf("The length: %d\n", getLength(stack1));
dispStack(stack1);
printf("the second:\n");
popStack(stack1);
printf("The length: %d\n", getLength(stack1));
dispStack(stack1);
popStack(stack1);
dispStack(stack1);
printf("The length: %d\n", getLength(stack1));
pushStack(stack1, );
dispStack(stack1);
printf("The length: %d\n", getLength(stack1)); return ;
}
测试函数完成所有函数的功能测试,功能通过就OK!
41深入理解C指针之---指针与栈的更多相关文章
- 00深入理解C指针之--- 指针之外
该系列文章源于<深入理解C指针>的阅读与理解,由于本人的见识和知识的欠缺可能有误,还望大家批评指教. C语言从诞生之初就非常善于和硬件打交道,经过这么多年的发展之后,其灵活性和超强的特征是 ...
- 02深入理解C指针之---指针类型和值
该系列文章源于<深入理解C指针>的阅读与理解,由于本人的见识和知识的欠缺可能有误,还望大家批评指教. 1.指针的类型: 可以在声明指针时,指定指针的类型,例如: (1)void *x 声 ...
- 06深入理解C指针之---指针操作和比较
该系列文章源于<深入理解C指针>的阅读与理解,由于本人的见识和知识的欠缺可能有误,还望大家批评指教. 指针作为一种特殊类型的变量,必须遵守C语言中变量先声明后使用的原则.本节内容中指针的操 ...
- 10深入理解C指针之---指针运算和比较
该系列文章源于<深入理解C指针>的阅读与理解,由于本人的见识和知识的欠缺可能有误,还望大家批评指教. 指针运算有很多种,主要有指针的声明*.指针的解引*.指针指向(*).或->.指针 ...
- 理解C语言中指针的声明以及复杂声明的语法
昨天刚把<C程序设计语言>中"指针与数组"章节读完,最终把心中的疑惑彻底解开了.如今记录下我对指针声明的理解.顺便说下怎样在C语言中创建复杂声明以及读懂复杂声明. 本文 ...
- 这样子来理解C语言中指针的指针
友情提示:阅读本文前,请先参考我的之前的文章<从四个属性的角度来理解C语言的指针也许会更好理解>,若已阅读,请继续往下看. 我从4个属性的角度来总结了C语言中的指针概念.对于C语言的一个指 ...
- 从四个属性的角度来理解C语言的指针也许会更好理解
文章会在文末更新! 关于指针是什么,很多教材已经作出了定义,大多数都会定义为"存放变量内存地址的变量".从这句话中我觉得除了让我知道这个定义有11个字以外,其他就没什么用了.我个人 ...
- 理解git 中的HEAD指针&branch指针
理解git 中的HEAD指针&branch指针 Yooye关注 2019.02.28 10:44:32字数 492阅读 668 HEAD指针 使用git checkout 来移动HEAD指针, ...
- 深入理解C语言-函数指针
函数指针在C++中有着重要的应用,函数的函数名其本质就是代表一个地址,这个地址叫做函数入口,得到这个地址就可以对这个函数进行各种操作. 函数类型基础 函数三要素: 名称.参数.返回值 C语言中的函数有 ...
- 深入理解C语言-二级指针三种内存模型
二级指针相对于一级指针,显得更难,难在于指针和数组的混合,定义不同类型的二级指针,在使用的时候有着很大的区别 第一种内存模型char *arr[] 若有如下定义 char *arr[] = {&quo ...
随机推荐
- SizeClass介绍
随着iOS8系统的发布,一个全新的页面UI布局概念出现,这个新特性将颠覆包括iOS7及之前版本的UI布局方式,这个新特性就是Size Class.Size Class配合Auto Layout可以解决 ...
- virtualvenv+django+uWSGI+nginx 部署
原创博文 转载请注明出处! 1. virtualvenv 2. django 3. uWSGI 4. nginx 5. 踩坑记录 1. virtualvenv virtualvenv install ...
- java--String、StringBuilder、StringBuffer的解析和比较?
一.String的解析 1.String的含义 ①String是不可以被继承的,String类是final类,String类是由char[]数组来存储字符串. ②String是不可变的字符序列,如果存 ...
- centOS下lnamp安装
首先安装apache,mysql ,最后安装php 1>apache安装 安装:yum install -y httpd 运行:/bin/systemctl start httpd.servic ...
- CSS基础(一)
一.CSS概述 CSS 指层叠样式表 (Cascading Style Sheets) 样式定义如何显示 HTML 元素 样式通常存储在样式表中 把样式添加到 HTML 4.0 中,是为了解决内容与表 ...
- linux优化之优化开机自启动服务
过滤出来需要的开机自启动项:chkconfig --list|grep 3:on|grep -v "crond|sshd|network|rsyslog|sysstat" ...
- python导出开发环境
1.导出开发环境的依赖包 本地开发完后,再把代码给别人之前,需要 pip freeze > pip123.txt 2.其他环境安装依赖包 pip install -r pip123.txt 其他 ...
- type和object
一.定义 1.object是所有新式类的父类 2.type是所有类的类 二.解析 下面通过代码来比较一下object和type的关系(__class__获取所属的类,__bases__获取父 ...
- CentOS7.2下Hadoop2.7.2的集群搭建
1.基本环境: 操作系统: Centos 7.2.1511 三台虚机: 192.168.163.224 master 192.168.163.225 node1 192.168.163.226 ...
- 【HIHOCODER 1589】回文子串的数量(Manacher)
描述 给定一个字符串S,请统计S的所有|S| * (|S| + 1) / 2个子串中(首尾位置不同就算作不同的子串),有多少个是回文字符串? 输入 一个只包含小写字母的字符串S. 对于30%的数据,S ...