考研c语言复习之栈

栈一般出选择题,队列选择题和大题都有

栈:只允许在一端 进行插入或删除操作的线性表即栈顶(top)

s.top=-1时栈为空

向栈中插入元素

s.top=s.top+1;s.data[s.top]=value; 这段代码可以用一行代码代替: s.data[++s.top]=value;

不懂i++和++i的有福了

++ i 是先加后赋值;i ++ 是先赋值后加;++i和i++都是分两步完成的

例题:当i=5时,s=(++i)+(++i)和s=(i++)+(i++)的值:

1、当i=5时,s=(++i)+(++i)=13 先算第一个(++i),++在前面,就把i先加1再把赋值,即先把i变为6然后再得出(++i)的值为6,这时i已经变为6了,

再计算第二个(++i),++在前面也是先把i加1后再赋值,不过这时的i已经为6了,第一步的时候把i变成6了的,然后加1的话就变成7了,所以第二个(++i)的值为7,s=(++i)+(++i)=6+7=13。

2、s=(i++)+(i++)=11 先算第一个(i++),i在前面,就先赋值再把i加1,即(i++)的值为5,i的值变为6,第二个(i++),i在前面,先赋值再把i加1,这个时候的i已经为6了,即(i++)的值为6,而i已经变为7了。所以s=(i++)+(i++)=5+6=11。

顺序存储实现栈

复制代码
typedef struct {

Elemtype data[50];
int top;
}SqStack;

而出栈 则是

S.data[top]=x;

s.top=s.top-1;

同样这两行代码等价于 S.data[S.top--]; 即元素先出栈在移动

出栈,入栈, 获取栈顶元素代码如下

复制代码
#include<iostream>
# define Maxsize 50 
typedef int Elemtype; 
using namespace std;
typedef struct {
	Elemtype data[Maxsize];
	int top;//始终指向栈顶 
}Sqstack;

void init(Sqstack &S)
{
	S.top=-1;//初始化栈 
}
bool StackEmpty(Sqstack S)
{
	if(S.top==-1)
	{
		return true;
	 } 
	 else
	 {
	 	return false;
	 }
}
bool Push(Sqstack &S,Elemtype data)
{
	//判断栈是否满
	if(S.top==Maxsize-1)
	{
		cout<<"stack if overflow"<<" "<<endl;
	 } 
	 else
	 {
	 	S.data[++S.top]=data;
	 	return true;
	 }
}

bool Gettop(Sqstack S,Elemtype &m)
{
	if(StackEmpty(S))
	{
		return false;
	}
	m=S.data[S.top];
	return true;
}
//出栈 
bool Pop(Sqstack &S,Elemtype &n)
{
	if(StackEmpty(S))
	{
		return false;
	 } 
	 else
	 {
	 	n=S.data[S.top--];//出栈 
	 	return true;
	 }
}

void print(Sqstack S)
{
	int i=0;
	for(i=0;i<=S.top;i++)
	{
		cout<<S.data[i]<<" ";
	}
	cout<<endl;
}
int main()
{
	Sqstack S;
	init(S);
	Elemtype m,n;
	bool flag,ret,ret2;
	Push(S,1);//栈底 
	Push(S,3);
	Push(S,6);
	Push(S,10);//栈顶 
	print(S);
	flag=StackEmpty(S);
	if(flag)
	{
		cout<<"stack is empty"<<endl;
	}
	ret=Gettop(S,m);
	if(ret)
	{
		cout<<"stack top is "<<m<<endl;
	}
	ret2=Pop(S,n);
	if(ret2)
	{
		cout<<"remove stack top is " << n<<" "<<endl;
	}
	ret=Gettop(S,m);
	if(ret)
	{
		cout<<"the new stack top is "<<m<<endl;
	}


	return 0; 
}
相关推荐
C++ 老炮儿的技术栈11 分钟前
squirrel语言全面介绍
开发语言·c++·笔记·学习
williamdsy40 分钟前
【JavaScript】记录一个奇怪的问题,前端一次提交注册,后端收到两次接口调用,网络只显示一个register请求
开发语言·前端·javascript
苹果.Python.八宝粥1 小时前
Python第六章06:列表的循环练习
开发语言·python
Trouvaille ~2 小时前
【Java篇】静动交融,内外有别:从静态方法到内部类的深度解析
java·开发语言·类和对象·javase·代码块·内部类·静态变量
火车叨位去19492 小时前
代码随想录算法训练营第十四天|替换数字
java·开发语言·算法
Stark、2 小时前
使用C++在Qt框架下调用DeepSeek的API接口实现自己的简易桌面小助手
开发语言·qt·deepseek
夜晚中的人海2 小时前
【C语言】字符串函数详解
android·c语言·数据库
奇妙之二进制2 小时前
C语言入门教程100讲(4)输入输出
linux·运维·c语言
酷酷的崽7983 小时前
C++异常处理完全指南:从原理到实战
c语言·c++
小样vvv3 小时前
Java 中的多线程:核心概念与应用场景
java·开发语言