用链表实现栈,完成了出栈入栈功能。

  #include"stdio.h"
typedef int element; //define a struct descirbe a stack used by linklist
typedef struct Stack_linklist{
element data;
struct Stack_linklist *next;
}*Stack; //define a struct desribe a stack top number
typedef struct Stack_top{
element top;
}*Top;
element pop(Stack pStack,Top pTop)
{
Stack P,K;
K=pStack->next;
printf("pop data:%d\n",pStack->next->data);
pStack->next=pStack->next->next;
free(K);
printf("pop position:%d\n",pTop->top);
--pTop->top;
} element Init(Stack *p_Stack,element num,Top pTop)
{
pTop->top=-;
Stack P,pStack;
pStack=*p_Stack;
int i=;
if(num<)
{
printf("please input right number\n");
}
for(;i<num;i++)
{
P=(Stack)malloc(sizeof(struct Stack_linklist));
pStack->next=P;
pStack=pStack->next;
pTop->top++;
pStack->data=i;
printf("pStack->data:%d\n",pStack->data);
}
pStack->next=NULL;
return ;
}
element push(Stack *pStack,element num,Top pTop)
{
Stack P,k,M;
M=(Stack)malloc(sizeof(struct Stack_linklist));
P=*pStack;
k=P->next;
P->next=M;
M->next=k;
M->data=num;
pTop->top++;
printf("push position:%d data:%d\n",pTop->top,M->data);
}
element Print(Stack pStack)
{
Stack P;
P=pStack->next;
while(P)
{
printf("data:%d\n",P->data);
P=P->next;
}
}
element main()
{
Stack P;
Top pTop;
pTop=(Top)malloc(sizeof(struct Stack_top));
P=(Stack)malloc(sizeof(struct Stack_linklist));
P->next=NULL;
Init(&P,,pTop);
Print(P);
push(&P,,pTop);
push(&P,,pTop);
push(&P,,pTop);
push(&P,,pTop);
push(&P,,pTop);
Print(P);
pop(P,pTop);
pop(P,pTop);
Print(P);
}

c语言编程之栈(链表实现)的更多相关文章

  1. C语言编程学习:链表的来源分析

    C语言是面向过程的,而C++是面向对象的 C和C++的区别: C是一个结构化语言,它的重点在于算法和数据结构.C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现 ...

  2. c语言编程之栈(数组实现)

    用数组实现的顺序栈,完成了出栈入栈功能. #include"stdio.h" typedef int element; #define max 100 typedef struct ...

  3. c语言编程之队列(链表实现)

    用链表实现了队列,完成了队列的入队和出队功能. #include"stdio.h" typedef int element; typedef struct Node{ struct ...

  4. C语言 复杂的栈(链表栈)

    //复杂的栈--链表栈 #include<stdio.h> #include<stdlib.h> #define datatype int//定义链表栈数据类型 //定义链表栈 ...

  5. 如何轻松使用 C 语言实现一个栈?​

    什么是数据结构? 数据结构是什么?要了解数据结构,我们要先明白数据和结构,数据就是一些int char 这样的变量,这些就是数据,如果你是一个篮球爱好者,那么你的球鞋就是你的数据,结构就是怎么把这些数 ...

  6. 不可或缺 Windows Native (9) - C 语言: 动态分配内存,链表,位域

    [源码下载] 不可或缺 Windows Native (9) - C 语言: 动态分配内存,链表,位域 作者:webabcd 介绍不可或缺 Windows Native 之 C 语言 动态分配内存 链 ...

  7. 混合语言编程:启用CLR(公共语言运行时编译)让C#调用C++

    前言 关于混合C#和C++的编程方式,本人之前写过一篇博客(参见混合语言编程:C#使用原生的Directx和OpenGL),在之前的博客中,介绍了在C#的Winform和WPF下使用原生的Direct ...

  8. 第二章 C语言编程实践

    上章回顾 宏定义特点和注意细节 条件编译特点和主要用处 文件包含的路径查询规则 C语言扩展宏定义的用法 第二章 第二章 C语言编程实践 C语言编程实践 预习检查 异或的运算符是什么 宏定义最主要的特点 ...

  9. 华为C语言编程规范

    DKBA华为技术有限公司内部技术规范DKBA 2826-2011.5C语言编程规范2011年5月9日发布 2011年5月9日实施华为技术有限公司Huawei Technologies Co., Ltd ...

随机推荐

  1. MongoDB - The mongo Shell, mongo Shell Quick Reference

    mongo Shell Command History You can retrieve previous commands issued in the mongo shell with the up ...

  2. 物联网 WIFI 一键配置原理(smartconfig) ESP8266/QCA4004

    自从物联网 问世以来,如何使得物  能够联网 有了很多的方式,目前运用非常广的WIFI,今天就总结下自这个方面,也对于有需要的盆友 也希望有抛砖引玉之效果. 物联网:  智能硬件+APP+云 APP ...

  3. Memcached 使用

    using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.UI ...

  4. ueditor 单独图片上传 转载

    <body> <script type="text/javascript"> //这个是图片上传的,网上还有附件上传的 (function($) { var ...

  5. 6步图文教你优化myeclipse2014

    MyEclipse 2014优化速度方案仍然主要有这么几个方面:去除无需加载的模块.取消冗余的配置.去除不必要的检查.关闭更新. 第一步: 去除不需要加载的模块 一个系统20%的功能往往能够满足80% ...

  6. QT 信号与槽连接

    转帖 http://www.cnblogs.com/cnhome/archive/2009/10/01/1577277.html 信号(SIGNAL)和槽(SLOT)是Qt编程的一个重要部分.这个机制 ...

  7. 3月3日(5) Roman to Integer

    原题 Roman to Integer 题意很简单,把Roman字母翻译成int. 实现方式也不难,针对每个字符转成int,从右往左,依次判断,如果当前值比上一个值大则相加,小则相减. 什么,你问我怎 ...

  8. mac实现jni的demo

    今天在看ArrayList 源码时看到了System.arraycopy 这个方法,但是这个方法没有java实现. 后面一通查询查找,才知道 如下图 native是一个java调用c语言来实现的操作的 ...

  9. JS对select动态添加options操作[IE&FireFox兼容]

    <select id="ddlResourceType" onchange="getvalue(this)"> </select> 动态 ...

  10. js中substring和substr的用法比较

    推荐使用substring 方法   stringObject.substring(start,stop)   stringObject.substr(start,length)   定义和用法 提取 ...