当前位置: 首页 > wzjs >正文

浙江金华网站建设整合营销活动策划方案

浙江金华网站建设,整合营销活动策划方案,东升手机网站建设,江苏建设人才网查询队列是一种常见的数据结构,它是一种先进先出(First-In-First-Out, FIFO)的线性表。在队列中,数据元素按照插入的顺序排列,最先插入的元素在队列的前面,最后插入的元素在队列的后面。类比生活中排队购物的情…

队列是一种常见的数据结构,它是一种先进先出(First-In-First-Out, FIFO)的线性表。在队列中,数据元素按照插入的顺序排列,最先插入的元素在队列的前面,最后插入的元素在队列的后面。类比生活中排队购物的情景,先到先得的原则就是队列的特点。

队列具有以下基本概念和特点:

  1. 入队(enqueue):向队列的末尾插入(或加入)一个新元素。
  2. 出队(dequeue):从队列的头部移除(或取出)一个元素。
  3. 队头(front):队列的头部,即队列中的第一个元素。
  4. 队尾(rear):队列的尾部,即队列中的最后一个元素。
  5. 空队列(empty queue):队列中不包含任何元素。
  6. 满队列(full queue):队列已满,无法再插入新元素。
  7. 队列的大小(queue size):队列中包含的元素个数。

队列常用于模拟各种实际场景,例如计算机系统中的任务调度、打印队列、操作系统中的进程调度等。在算法和数据结构中,队列也是一种重要的基础数据结构,常用于解决各种问题,如广度优先搜索、树和图的遍历等。
在这里插入图片描述
队列的项目结构目录

在这里插入图片描述
头文件QueueStorage.h
在这里插入图片描述头文件QueueStorage.h代码

#ifndef SEQQUEUE_H
#define SEQQUEUE_H
#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 1024// 顺序存储类似于数组定义一个结构体即可
typedef struct SEQQUEUE {// 无类型指针,可以接收如何数据类型的数据void* data[MAX_SIZE];// 数组的大小int size;}SeqQueue;
// 初始化结构体
SeqQueue* Init_SeqQueue();
// 入队列
void Push_SeqQueue(SeqQueue* queue, void* data);
// 返回对头元素
void* Front_SeqQueue(SeqQueue* queue);
// 出队列
void* Pop_SeqQueue(SeqQueue* queue);
// 返回队尾的元素
void* Back_SeqQueue(SeqQueue* queue);
// 返回大小
int Size_SeqQueue(SeqQueue* queue);
//清空队列
void* Clear_SeqQueue(SeqQueue* queue);
// 销毁队列
void* FreeSpace_SeqQueue(SeqQueue* queue);#endif

cpp文件截图

在这里插入图片描述cpp文件代码

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <iostream>
#include <string.h>
#include "QueueStorage.h"
// 初始化结构体
SeqQueue* Init_SeqQueue() {SeqQueue* queue = (SeqQueue*)malloc(sizeof(SeqQueue));// 使用for循环对队列进行初始化for (int i = 0; i < MAX_SIZE; i++) {// 将队列初始化为NULLqueue->data[i] = NULL;}queue->size = 0;return queue;
};
// 入队列
void Push_SeqQueue(SeqQueue* queue, void* data) {// 确定数组的哪一个方向是对头:将数组的左边作为对头if (queue == NULL) {return;}if (data == NULL) {return;}// 将元素插入数组中,元素的移动if (queue->size == MAX_SIZE) {return;}queue->data[queue->size] = data;queue->size++;
};
// 返回对头元素
void* Front_SeqQueue(SeqQueue* queue) {if (queue == NULL) {return NULL;}if (queue->size == 0) {return NULL;}return queue->data[0];
};
// 出队列
void* Pop_SeqQueue(SeqQueue* queue) {// 移动元素if (queue == NULL) {return NULL;}if (queue->size == 0) {return NULL;}for (int i = 0; i < queue->size - 1; i++) {queue->data[i] = queue->data[i + 1];}queue->size--;
};
// 返回队尾的元素
void* Back_SeqQueue(SeqQueue* queue) {if (queue == NULL) {return NULL;}if (queue->size == 0) {return NULL;}return queue->data[queue->size-1];
};
// 返回大小
int Size_SeqQueue(SeqQueue* queue) {if (queue == NULL) {return -1 ;}return queue->size;
};
//清空队列
void* Clear_SeqQueue(SeqQueue* queue) {if (queue == NULL) {return NULL;}queue->size = 0;
};
// 销毁队列
void* FreeSpace_SeqQueue(SeqQueue* queue) {if (queue == NULL) {return NULL;}free(queue);
};

主文件截图main.cpp
在这里插入图片描述主文件代码mian.cpp

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <iostream>
#include <string.h>
#include "QueueStorage.h"typedef struct PERSON {char name[64];int age;}Person;int main()
{SeqQueue* queue = Init_SeqQueue();// 创建数据Person p1 = { "aaa",10 };Person p2 = { "bbb",20 };Person p3 = { "ccc",30 };Person p4 = { "ddd",40 };Person p5 = { "eee",50 };//数据入队列调用push函数Push_SeqQueue(queue, &p1);Push_SeqQueue(queue, &p2);Push_SeqQueue(queue, &p3);Push_SeqQueue(queue, &p4);Push_SeqQueue(queue, &p5);// 输出队尾元素Person* backPerson = (Person*)Back_SeqQueue(queue);printf("name:%s age:%d", backPerson->name, backPerson->age);//输出while (Size_SeqQueue(queue) > 0) {// 取出对头元素Person* p = (Person*)Front_SeqQueue(queue);// 输出printf("name = %s age = %d \n",p->name,p->age);// 从对头弹出元素Pop_SeqQueue(queue);}// 销毁队列FreeSpace_SeqQueue(queue);system("pause");return 0;
}

项目运行结果展示
在这里插入图片描述

http://www.dtcms.com/wzjs/87140.html

相关文章:

  • seddog站长之家浙江网络推广公司
  • 网站建设如何做用户名密码宁波网络推广seo软件
  • 上海网站建设 微信开发公司b站软件推广大全
  • 国外做饰品批发网站seo工具是什么意思
  • 做商城的网站程序西点培训学校
  • 湖南网站开发哪家好百度账号快速注册入口
  • 网站seo的关键词排名怎么做的外链seo推广
  • 为什么招聘网站不能用自己做的简历搜狗营销
  • 这几年做啥网站致富外贸seo推广公司
  • 平面设计网址推荐手机端关键词排名优化软件
  • 泸州百度做网站联系北京seo关键词排名
  • 二进制可以做网站是吗如何建网站要什么条件
  • 临清做网站搜索广告优化
  • 做公司网站需要多长时间公司网站建设需要多少钱
  • 网站建设总结报告小红书软文案例
  • 云梦建站百度指数官网查询入口
  • 网站建设架网络营销的4p策略
  • 北京做网站软件seo标题优化是什么意思
  • 十大网购平台seo入门培训学多久
  • 全国建设注册中心网站宁波seo推广优化公司
  • 广告网站建设报价十大营销案例分析
  • 温州地区做网站河南网站关键词优化
  • 电影网站怎么做流量百度竞价托管
  • aspx网站html静态化怎么做我要登录百度
  • 官方网站、门户网站是什么意思?杭州优化排名哪家好
  • 做网页跳转网站宁波seo网络推广定制多少钱
  • 电影网站app怎么做的线上网络推广怎么做
  • 天津市建设工程质量安全监督管理总队网站站长之家ping
  • 325建筑人才网招聘重庆seo排名优化
  • 做招聘网站的怎么引流求职者培训总结