码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • “顽固”——C语言用栈实现队列


     解题图解:

    1、 先用stack1存储push来的数据

     

    2、每当要pop数据时,从stack2中取,如果 stack2为空,就先从stack1中“倒”数据到stack2。

     这就是用栈实现队列的基本操作

     这道题看起来比较容易,但是!如果你用C语言去去做,你还得自己去写一个栈,栈不知道写的可以看看之前的一篇文章——数据结构(C语言)——栈的两种实现方式

    本题使用 动态数组构造栈

    1. #define E int
    2. typedef struct my_stack{
    3. int pos;
    4. int capcity;
    5. E* stack;
    6. }my_stack;
    7. void initiaze(my_stack* mystack);
    8. void stack_push(my_stack* mystack,E element);
    9. void initiaze(my_stack* mystack){
    10. mystack->pos=0;
    11. mystack->capcity=1;
    12. mystack->stack=(E*)malloc(sizeof(E));
    13. }
    14. void stack_push(my_stack* mystack,E element){
    15. if(mystack->pos==mystack->capcity){//扩容
    16. mystack->capcity *= 2;
    17. mystack->stack=(E*)realloc(mystack->stack,(mystack->capcity)*sizeof(E));
    18. }
    19. mystack->stack[mystack->pos]=element;
    20. mystack->pos++;
    21. }
    22. typedef struct {
    23. my_stack* stack1;
    24. my_stack* stack2;
    25. } MyQueue;
    26. MyQueue* myQueueCreate() {
    27. my_stack* s1=(my_stack*)malloc(sizeof(my_stack));
    28. my_stack* s2=(my_stack*)malloc(sizeof(my_stack));
    29. initiaze(s1);
    30. initiaze(s2);
    31. MyQueue* my_queue = (MyQueue*)malloc(sizeof(MyQueue));
    32. my_queue->stack1=s1;
    33. my_queue->stack2=s2;
    34. return my_queue;
    35. }
    36. void myQueuePush(MyQueue* obj, int x) {
    37. stack_push(obj->stack1,x);
    38. }
    39. int myQueuePop(MyQueue* obj) {
    40. if(obj->stack2->pos==0){
    41. while(obj->stack1->pos){
    42. stack_push(obj->stack2,obj->stack1->stack[obj->stack1->pos-1]);
    43. obj->stack1->pos--;
    44. }
    45. }
    46. E ele= obj->stack2->stack[obj->stack2->pos-1];
    47. obj->stack2->pos--;
    48. return ele;
    49. }
    50. int myQueuePeek(MyQueue* obj) {
    51. if(obj->stack2->pos==0){
    52. while(obj->stack1->pos){
    53. stack_push(obj->stack2,obj->stack1->stack[obj->stack1->pos-1]);
    54. obj->stack1->pos--;
    55. }
    56. }
    57. return obj->stack2->stack[obj->stack2->pos-1];
    58. }
    59. bool myQueueEmpty(MyQueue* obj) {
    60. if(obj->stack2->pos==0 && obj->stack1->pos==0)return true;
    61. return false;
    62. }
    63. void myQueueFree(MyQueue* obj) {
    64. free(obj->stack1->stack);
    65. free(obj->stack2->stack);
    66. free(obj->stack1);
    67. free(obj->stack2);
    68. free(obj);
    69. }

     

  • 相关阅读:
    LeetCode_字符串_简单_1071.字符串的最大公因子
    springboot 核心技术---配置文件
    530. 二叉搜索树的最小绝对差
    OmniGraffle Pro for Mac 中文正式版(附注册码) 苹果电脑 思维导图软件
    学内核之九:学会偷懒,善用内核的调试日志
    从模型复杂度角度来理解过拟合现象
    java 调用合约使用nonce 可能会出现的问题
    Kafka:分布式流处理平台的深度解析
    在线PDF查看器和PDF编辑器:GrapeCity Documents PDF (GcPdf)
    学习记录639@python机器学习模型部署与访问实战-基于Flask
  • 原文地址:https://blog.csdn.net/weixin_56821642/article/details/133049211
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号