堆栈(stack)

本文介绍了一个简单的堆栈类实现,并通过实例演示了如何使用Push和Pop方法进行数据的压栈和出栈操作。

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

http://bbs.cnlsj.com/UploadFile/2008-10/2008101716184869666.swf

堆栈的特性为先进后出(First In Last Out,FILO)。Push 压栈;Pop 出栈。

 

#include<windows.h>

#include<stdio.h>

 

//结构体--基本函数

struct stUnit

{

     char szName[64];//存放名字的

};

 

//堆栈类

class clStack

{

private:

     stUnit *mBuffer;//Buffer 缓冲器

     unsigned int mBufSize;//缓存大小

    unsigned int mCount;//这个很不稳当~~~不知道什么意思

public:

     //---------------------------------构造函数-------------------------

     clStack(unsigned int nBufSize): mBuffer(NULL),mBufSize(0),mCount(0)//私有变量初始化

     {

         if (nBufSize<10)

         {

              nBufSize=10;

         }

         mBufSize=nBufSize;

         mBuffer=new stUnit[mBufSize] ;//缓存地址

 

     }

     //---------------------------------析构函数-------------------------

     ~clStack()

     {

       if (mBuffer !=NULL)

       {

         delete [] mBuffer;

         mBuffer=NULL;

       }

        mCount=0;

        mBufSize=0;

     }

     //---------------------------------进栈方法--------------------------

     bool Push(stUnit Unit)//People[0]People[1]People[2]

     {

         if (mCount>=mBufSize)//mBufSize=10

         {

              return false;

         }

         mBuffer[mCount++]=Unit;//stUnit *mBuffer;//Buffer 缓冲器

         //mCount= 123

         return true;

     }

     //---------------------------------出栈方法--------------------------

     bool Pop(stUnit &Unit)

     {

       if(mCount==0)

       {

           return false;

       }

       --mCount;

       //mCount= 321

       Unit=mBuffer[mCount];

       return true;

     }

};

 

 

int main(int argc,char *argv[])

{

     //stUnit结构体 存放姓名;clStack 类(PushPop方法)

     int loop;

     clStack stack(10);//初始化缓存大小 mBufSize=10

     stUnit People[3],Person;

     strcpy(People[0].szName,"Peter");

    strcpy(People[1].szName,"Mary");

    strcpy(People[2].szName,"John");

     printf("Push data into stack.\n");

    //------------------------压栈---------------------------

     for (loop=0;loop<3;loop++)

     {

         printf("%s\n",People[loop].szName);

         stack.Push(People[loop]);//压栈

     }

     printf("\nPop data from stack.\n");

    //------------------------出栈---------------------------

     for (loop=0;loop<3;loop++)

     {

         stack.Pop(Person);

         printf("%s\n",Person.szName);

     }

 

     return 0;

}

 

 

内容概要:该研究通过在黑龙江省某示范村进行24小时实地测试,比较了燃煤炉具与自动/手动进料生物质炉具的污染物排放特征。结果显示,生物质炉具相比燃煤炉具显著降低了PM2.5、CO和SO2的排放(自动进料分别降低41.2%、54.3%、40.0%;手动进料降低35.3%、22.1%、20.0%),但NOx排放未降低甚至有所增加。研究还发现,经济性和便利性是影响生物质炉具推广的重要因素。该研究不仅提供了实际排放数据支持,还通过Python代码详细复现了排放特征比较、减排效果计算和结果可视化,进一步探讨了燃料性质、动态排放特征、碳平衡计算以及政策建议。 适合人群:从事环境科学研究的学者、政府环保部门工作人员、能源政策制定者、关注农村能源转型的社会人士。 使用场景及目标:①评估生物质炉具在农村地区的推广潜力;②为政策制定者提供科学依据,优化补贴政策;③帮助研究人员深入了解生物质炉具的排放特征和技术改进方向;④为企业研发更高效的生物质炉具提供参考。 其他说明:该研究通过大量数据分析和模拟,揭示了生物质炉具在实际应用中的优点和挑战,特别是NOx排放增加的问题。研究还提出了多项具体的技术改进方向和政策建议,如优化进料方式、提高热效率、建设本地颗粒厂等,为生物质炉具的广泛推广提供了可行路径。此外,研究还开发了一个智能政策建议生成系统,可以根据不同地区的特征定制化生成政策建议,为农村能源转型提供了有力支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值