11/7/5 deque 学习笔记

 

<deque>叫做双端队列容器,其功能与矢量容器相似,包括相同的成员函数,不同的是可以在头尾两个方向有效地删除和添加元素。

push_front()  函数可以实现在头部添加元素,其使用方法与push_back()  类似

pop_front()   可以在头部删除一个元素

由于双端队列的内存管理更为复杂,所以若不是一定要在头部操作,就选用矢量容器

 

<numeric> 头文件

其函数:  accumulate(起始 , 终了的下一位 , 0)  可是实现求和运算,对一个序列进行求和,第三个参数是和的初始值

 

反向迭代器的类型是  deque<T>::reverse_iterator , 通常反向迭代器声明为 riter

 

一系列用逗号隔开的表达式,其值是由最右端的一个表达式决定的。 例如, while(cin>>value , value!=0 )  ……;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是使用数组实现双头队列的代码示例: ``` #include <stdio.h> #include <stdlib.h> #define Type int // 定义元素类型 typedef struct Deque{ Type *array; // 数组 int ihead; // 头索引 int itail; // 尾索引 int entry_count; // 现存数据数量 int array_capacity; // 容量大小 }Deque, *Deque_link; // 初始化双头队列 void init_deque(Deque_link deque, int capacity) { deque->array = (Type*)malloc(sizeof(Type) * capacity); deque->ihead = 0; deque->itail = capacity - 1; deque->entry_count = 0; deque->array_capacity = capacity; } // 判断队列是否为空 int is_empty(Deque_link deque) { return deque->entry_count == 0; } // 判断队列是否已满 int is_full(Deque_link deque) { return deque->entry_count == deque->array_capacity; } // 获取队列长度 int size(Deque_link deque) { return deque->entry_count; } // 从队头入队 void push_front(Deque_link deque, Type value) { if (is_full(deque)) { printf("Deque is full, cannot push_front!\n"); return; } deque->array[deque->ihead] = value; deque->ihead = (deque->ihead + 1) % deque->array_capacity; deque->entry_count++; } // 从队尾入队 void push_back(Deque_link deque, Type value) { if (is_full(deque)) { printf("Deque is full, cannot push_back!\n"); return; } deque->array[deque->itail] = value; deque->itail = (deque->itail - 1 + deque->array_capacity) % deque->array_capacity; deque->entry_count++; } // 从队头出队 Type pop_front(Deque_link deque) { if (is_empty(deque)) { printf("Deque is empty, cannot pop_front!\n"); return -1; } Type value = deque->array[(deque->ihead - 1 + deque->array_capacity) % deque->array_capacity]; deque->ihead = (deque->ihead - 1 + deque->array_capacity) % deque->array_capacity; deque->entry_count--; return value; } // 从队尾出队 Type pop_back(Deque_link deque) { if (is_empty(deque)) { printf("Deque is empty, cannot pop_back!\n"); return -1; } Type value = deque->array[(deque->itail + 1) % deque->array_capacity]; deque->itail = (deque->itail + 1) % deque->array_capacity; deque->entry_count--; return value; } int main() { Deque deque; int capacity = 10; init_deque(&deque, capacity); // 从队头入队 for (int i = 0; i < 5; i++) { push_front(&deque, i); } // 从队尾入队 for (int i = 5; i < 10; i++) { push_back(&deque, i); } // 从队头出队 while (!is_empty(&deque)) { printf("%d ", pop_front(&deque)); } printf("\n"); // 从队尾出队 for (int i = 0; i < 5; i++) { push_front(&deque, i); } while (!is_empty(&deque)) { printf("%d ", pop_back(&deque)); } printf("\n"); return 0; } ``` 在上面的代码中,我们使用了一个数组来存储双头队列中的元素。`ihead` 表示队头的位置,`itail` 表示队尾的位置,`entry_count` 表示队列中现存的元素数量,`array_capacity` 表示数组的容量大小。在初始化双头队列时,我们先动态分配一个数组,并将队头和队尾的位置分别初始化为 0 和 `capacity - 1`。当队列满时,我们无法继续插入元素,当队列为空时,我们无法出队元素。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值