“顽固”——C语言用栈实现队列

解题图解:

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

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

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

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

本题使用 动态数组构造栈

cpp 复制代码
#define E int

typedef struct my_stack{
  int pos;
  int capcity;
  E* stack;
}my_stack;
void initiaze(my_stack* mystack);
void stack_push(my_stack* mystack,E element);
void initiaze(my_stack* mystack){
  mystack->pos=0;
  mystack->capcity=1;
  mystack->stack=(E*)malloc(sizeof(E));
}

void stack_push(my_stack* mystack,E element){
  if(mystack->pos==mystack->capcity){//扩容
   mystack->capcity *= 2;
   mystack->stack=(E*)realloc(mystack->stack,(mystack->capcity)*sizeof(E));
  }
  mystack->stack[mystack->pos]=element;
  mystack->pos++;
}

typedef struct {
  my_stack* stack1;
  my_stack* stack2;
} MyQueue;


MyQueue* myQueueCreate() {
  my_stack* s1=(my_stack*)malloc(sizeof(my_stack));
  my_stack* s2=(my_stack*)malloc(sizeof(my_stack));
  initiaze(s1);
  initiaze(s2);
  MyQueue* my_queue = (MyQueue*)malloc(sizeof(MyQueue));
  my_queue->stack1=s1;
  my_queue->stack2=s2;
  return my_queue;
}

void myQueuePush(MyQueue* obj,  int x) {
  stack_push(obj->stack1,x);
}

int myQueuePop(MyQueue* obj) {
  if(obj->stack2->pos==0){
    while(obj->stack1->pos){
      stack_push(obj->stack2,obj->stack1->stack[obj->stack1->pos-1]);
      obj->stack1->pos--;
    }
  }
  E ele= obj->stack2->stack[obj->stack2->pos-1];
  obj->stack2->pos--;
  return ele;
}

int myQueuePeek(MyQueue* obj) {
  if(obj->stack2->pos==0){
    while(obj->stack1->pos){
      stack_push(obj->stack2,obj->stack1->stack[obj->stack1->pos-1]);
      obj->stack1->pos--;
    }
  }
  return obj->stack2->stack[obj->stack2->pos-1];
}

bool myQueueEmpty(MyQueue* obj) {
  if(obj->stack2->pos==0 && obj->stack1->pos==0)return true;
  return false;
}

void myQueueFree(MyQueue* obj) {
  free(obj->stack1->stack);
  free(obj->stack2->stack);
  free(obj->stack1);
  free(obj->stack2);
  free(obj);
}
相关推荐
刘马想放假21 小时前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠2 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦9 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
LDR00610 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术10 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园10 天前
C++20 Modules 模块详解
java·开发语言·spring
swordbob10 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
小小工匠10 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
源分享10 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.10 天前
C语言--day30
c语言·开发语言