实验二:栈与队列的实现与应用

本文介绍了两种基本的数据结构——栈和队列的实现方法。包括顺序栈、链栈、顺序队列和链队列的创建、操作及使用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、顺序栈:

#include <iostream>

using namespace std;

const int StackSize=10;

class SeqStack{

public:

SeqStack(); //构造函数,初始化一个空栈

~SeqStack(){} 

void Push(int x); 

int Pop(); 

int GetTop();

int Empty();

private:

int data[StackSize];//存放栈元素的数组

int top; //栈顶指针,为栈顶元素在数组中的下标

};

SeqStack::SeqStack(){

top=-1;}

void SeqStack::Push(int x){

if(top==StackSize-1)throw "上溢";

data[++top]=x;}

int SeqStack::Pop(){

if(top==-1)throw"下溢";

int x=data[top--];

return x;}

int SeqStack::GetTop(){

if(top!=-1)

return data[top];}

int SeqStack::Empty()

if(top==-1)return 1;

else return 0;

}

void main(){

SeqStack k1;

if(k1.Empty())

cout<<"栈为空"<<"\n"<<endl;

else

cout<<"栈非空"<<endl;

cout<<"对99和88执行入栈操作"<<"\n"<<endl;

k1.Push(99);

k1.Push(88);

cout<<"栈顶元素为:"<<"\n"<<endl;

cout<<k1.GetTop()<<"\n"<<endl;

cout<<"执行一次出栈操作"<<"\n"<<endl;

k1.Pop();

cout<<"栈顶元素为:"<<"\n"<<endl;

cout<<k1.GetTop()<<"\n"<<endl;}


2、链栈:

#include<iostream>

using namespace std;

struct Node

{

int data;

Node *next;

};

class LinkStack{

public:

LinkStack();

~LinkStack();

void Push(int x);

int Pop();

int GetTop();

int Empty();

private:

Node *top;

};

//构造函数

LinkStack::LinkStack(){

top=new Node;

top=NULL;}

//压栈函数

void LinkStack::Push(int x){

Node *s=NULL;

s=new Node;

s->data=x;

s->next=top;

top=s;}

//弹栈函数

int LinkStack::Pop(){

if(top==NULL)throw"下溢";

else

int x;Node *p=NULL;

p=top;

x=top->data;

top=top->next;

delete p;

return x;}

//取栈顶元素

int LinkStack::GetTop(){

if(top!=NULL)

return top->data;}

//判空函数

int LinkStack::Empty(){

if(top==NULL)

return 1;

else return 0;}

//析构函数

LinkStack::~LinkStack(){

Node *q=NULL;

while(top!=NULL)

q=top;

top=top->next;

delete q;}

//主函数

void main(){

LinkStack s;

if(s.Empty())

cout<<"此栈为空!"<<"\n"<<endl;

else

cout<<"此栈不为空"<<"\n"<<endl;

cout<<"对99和88进行压栈操作""\n"<<endl;

s.Push(99);

s.Push(88);

cout<<"栈顶元素为:"<<"\n"<<endl;

cout<<s.GetTop()<<"\n"<<endl;

cout<<"执行一次弹栈操作"<<"\n"<<endl;

s.Pop();

cout<<"栈顶元素为:"<<"\n"<<endl;

cout<<s.GetTop()<<"\n"<<endl;}

3、顺序队列

#include <iostream> 

using namespace std; 

const int MAX=10; 

class Queue{ 

private: 

   int front; 

   int rear; 

   int data[MAX]; 

public: 

    Queue(){front=rear=MAX-1;} 

   ~Queue(){} 

   void EnQueue(int x); 

   int DeQueue(); 

   int GetQueue(){if (front!=rear) return data[(front+1)%MAX];}; 

   int Empty(); 

}; 

void Queue::EnQueue(int x){ 

   if ((rear-1)%MAX==front) throw "上溢"; 

   rear=(rear+1)%MAX; 

   data[rear]=x; 

int Queue::DeQueue(){ 

   if (front==rear) throw "下溢"; 

   int x=data[front]; 

   front=(front+1)%MAX; 

   return x; 

int Queue::Empty(){ 

   if (front==rear) return 1; else return 0; 

int main(){ 

   Queue S; 

   if (S.Empty()) 

       cout<<"队为空!"<<endl; 

   else 

       cout<<"队不为空!"<<endl; 

   cout<<"1入队:"<<endl; 

   S.EnQueue(1); 

   cout<<"2入队:"<<endl;

 S.EnQueue(2); 

   cout<<"取队头:"<<endl; 

   cout<<S.GetQueue()<<endl; 

   cout<<"一次出队:"<<endl; 

   S.DeQueue(); 

   cout<<"取队头:"<<endl; 

   cout<<S.GetQueue()<<endl; 

   return 0; 

}  

4、链队列

#include <iostream> 

using namespace std; 

struct Data { 

   int data; 

   struct Data *next; 

} *q; 

class Queue{ 

private: 

    Data *rear,*front; 

public: 

   Queue(){rear=NULL;front=NULL;} 

   ~Queue(){} 

   void EnQueue(int x); 

   int DeQueue(); 

    intGetQueue(); 

   int Empty(); 

}; 

void Queue::EnQueue(int x){ 

   q=new  Data; 

   q->data=x; 

   q->next=NULL; 

   if (Empty()) 

       front=rear=q;     //若队为空,让队头和队尾指针都指向新增空间 

   else { 

       rear->next=q; 

       rear=q;} 

int Queue::DeQueue(){ 

   if (Empty()) throw "下溢"; 

   q=front; 

   int x=front->data; 

   front=front->next; 

   delete q; 

   return x; 

 

int Queue::GetQueue(){ 

   if (!Empty()) 

       return front->data; 

 

int Queue::Empty(){ 

   if (front==NULL&&rear==NULL) return 1;  

   else return 0; 

int main(){ 

   Queue S; 

   if (S.Empty()) 

       cout<<"队为空!"<<endl; 

   else 

       cout<<"队不为空!"<<endl; 

   cout<<"10入队:"<<endl; 

   S.EnQueue(10); 

   cout<<"5入队:"<<endl; 

   S.EnQueue(5); 

   cout<<"取队头元素:"<<endl; 

   cout<<S.GetQueue()<<endl; 

   cout<<"一次出队:"<<endl; 

   S.DeQueue(); 

   cout<<"取队头元素:"<<endl; 

   cout<<S.GetQueue()<<endl; 

   return 0; 

}





内容概要:本文从关键概念、核心技巧、应用场景、代码案例分析及未来发展趋势五个维度探讨了Python编程语言的进阶之路。关键概念涵盖装饰器、生成器、上下文管理器、元类异步编程,这些概念有助于开发者突破基础认知的核心壁垒。核心技巧方面,介绍了内存优化、性能加速、代码复用异步处理的方法,例如使用生成器处理大数据流、numba库加速计算密集型任务等。应用场景展示了Python在大数据处理、Web开发、人工智能自动化运维等多个领域的广泛运用,特别是在FastAPI框架中构建异步API服务的实战案例,详细分析了装饰器日志记录、异步数据库查询性能优化技巧。最后展望了Python的未来发展趋势,包括异步编程的普及、类型提示的强化、AI框架的深度整合以及多语言协同。 适合人群:已经掌握Python基础语法,希望进一步提升编程技能的开发者,特别是有意向从事数据科学、Web开发或AI相关工作的技术人员。 使用场景及目标:①掌握Python进阶概念技术,如装饰器、生成器、异步编程等,提升代码质量效率;②学习如何在实际项目中应用这些技术,如通过FastAPI构建高效的异步API服务;③了解Python在未来编程领域的潜在发展方向,为职业规划提供参考。 阅读建议:本文不仅提供了理论知识,还包含了丰富的实战案例,建议读者在学习过程中结合实际项目进行练习,特别是尝试构建自己的异步API服务,并通过调试代码加深理解。同时关注Python社区的发展动态,及时掌握最新的技术工具。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值