剑指offer--2

简介: 前言:继续笔记分享! 面试题6:暂无好的解决方法先搁浅一下 面试题7: #include #include typedef struct LIFO{ int *data; int maxlen; int top; }seqstack_t; ty...

前言:继续笔记分享!

面试题6:暂无好的解决方法先搁浅一下

面试题7:

#include<stdio.h>
#include<stdlib.h>

typedef struct LIFO{
    int *data;
    int maxlen;
    int top;
}seqstack_t;
typedef struct LIFO1{
    int *data;
    int maxlen;
    int top;
}seqstack_t1;

//创建一个空栈
seqstack_t *CreateStack(int max)
{
    seqstack_t *H;
    H = (seqstack_t *)malloc(sizeof(seqstack_t));
    H->data = (int *)malloc(sizeof(int)*max);
    H->maxlen = max;
    H->top = 0;
    return H;
}
//创建一个空栈
seqstack_t1 *CreateStack1(int max)
{
    seqstack_t1 *H;
    H = (seqstack_t1 *)malloc(sizeof(seqstack_t1));

    H->data = (int *)malloc(sizeof(int)*max);
    H->maxlen = max;
    H->top = 0;
    return H;
}

//获取栈顶数据的值
int GetTop(seqstack_t1 *H)
{
    if(H->top <= 0)
    {
            printf("栈空\n");
            return -1;
    }
    return H->data[H->top-1];
}

//栈清空
void Clear(seqstack_t *H)
{
    H->top=0;
}

//向栈中插入数据
void Push(seqstack_t *H,int m)
{
    H->data[H->top]=m;
    H->top++;
}
//向栈中插入数据
void Push1(seqstack_t1 *H,int m)
{
    H->data[H->top]=m;
    H->top++;
}

int Pop(seqstack_t *H)
{
    return H->data[H->top];
}

int main()
{
    seqstack_t *T=CreateStack(10);
    seqstack_t1 *T1=CreateStack1(10);
    Push(T,1);
    Push(T,2);
    Push(T,3);
    
    int i=0;
    --T->top;
    while(T->top >= 0)
    {                
        Push1(T1,Pop(T));       
        i++;
        --T->top;
      }        
    while(T1->top > 0)
    {
        printf("data:%-5d",GetTop(T1));        
        --T1->top;
      }    
    printf("\n");

    free(T->data);
    free(T);
    free(T1->data);
    free(T1);
    return 0;
}

注:主要要懂栈后进先出LIFO,队列先进先出FIFO,一个栈弹出,一个压入,就可以实现队列!!!

 

作者: 柳德维

-------------------------------------------

个性签名:独学而无友,则孤陋而寡闻。做一个灵魂有趣的人!

如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!

万水千山总是情,打赏一分行不行,所以如果你心情还比较高兴,也是可以扫码打赏博主,哈哈哈(っ•̀ω•́)っ⁾⁾!

目录
相关文章
|
开发工具 开发者
如何创建短信模板 | 学习笔记
快速学习如何创建短信模板
如何创建短信模板 | 学习笔记
|
11月前
|
边缘计算 自动驾驶 物联网
探索云计算的边缘计算:定义、优势及应用前景
探索云计算的边缘计算:定义、优势及应用前景
|
缓存 负载均衡 架构师
阿里资深架构师钟华曰:中台战略思想与架构实战;含内部实施手册
最近在读一本书,叫做《企业IT架构转型之道:阿里巴巴中台战略思想与架构实战》,在写此文时本书还没有看完,因为担心如果把书全部看完后再来写这篇文章,很多精彩的内容可能已经忘记了,所以中途先写一篇来分享给大家。
|
SQL 关系型数据库 MySQL
[MySQL]——SQL预编译、动态sql
[MySQL]——SQL预编译、动态sql
803 0
带你读《5G大规模天线增强技术》——2.2.4 多普勒频谱
带你读《5G大规模天线增强技术》——2.2.4 多普勒频谱
|
JavaScript 前端开发 Shell
如何运行Node.js脚本及读取环境变量
如何运行Node.js脚本及读取环境变量
|
机器学习/深度学习 开发框架 人工智能
|
存储 传感器 人工智能
开发环境配置整理大全——Visual Studio 2022安装篇
Visual Studio是微软的集成开发环境(IDE),以Windows为主的平台开发的一套功能全面而强大的IDE,支持C#、F#、VB、C/C++、HTML等36 种语言的开发。 开发人员常使用的开发工具之一,Visual Studio今年出了最新版本的2022款,像我们之前常使用的是Visual Studio 2019。2022版本还是挺香的。
开发环境配置整理大全——Visual Studio 2022安装篇
|
缓存 分布式计算 数据可视化
Quick BI产品核心功能大图(四)Quick引擎加速:十亿数据亚秒级分析
随着数字化进程的深入,数据应用的价值被越来越多的企业所重视。基于数据进行决策分析是应用价值体现的重要场景,不同行业和体量的公司广泛依赖BI产品制作报表、仪表板和数据门户,以此进行决策分析。
1021 0
|
编解码 索引
信道质量指示(CQI)和编码调制方案(MCS) | 带你读《5G-NR信道编码》之十五
低密度校验码(LDPC)之信道质量指示(CQI)和编码调制方案(MCS)。
25255 0
信道质量指示(CQI)和编码调制方案(MCS) | 带你读《5G-NR信道编码》之十五