08数据结构—队列顺序存储

思想:

队列跟栈不一样,特点为先进先出。这里用数组进行搭建连续内存储存。以数组第一个下标进行进队和出队等操作。

代码实现:

头文件.h

#pragma once
#include <iostream>
using namespace std;
#define MAX_SIZE 5
//创建结构体 顺序 连续内存空间 数组框架
typedef struct My_Queue{
	void* data[MAX_SIZE];
	int size;
}queue;
//创建
queue* init_que();
//增加
void push_que(queue* que,void*data);
//删除
void pop_que(queue* que);
//返回头部元素
void* top_que(queue* que);
//摧毁内存空间
void free_que(queue* que);
//大小
int size_que(queue* que);

.cpp文件

#include "Queue.h"

queue* init_que()
{
    queue* que = (queue*)malloc(sizeof(queue));
    que->size = 0;
    for (int i = 0;i<MAX_SIZE;i++) {
        que->data[i] = NULL;
    }
    return que;
}

void push_que(queue* que,void* data)
{
    if (que == NULL) {
        cout<<"链表数据为空!" << endl;
    }
    que->data[que->size] = data;
    que->size++;
}

void pop_que(queue* que)
{
    if (que == NULL) {
        cout << "链表数据为空!" << endl;
    }
    for (int i = 0;i<que->size;i++) {
        que->data[i] = que->data[i + 1];
    }
    que->size--;
}

void* top_que(queue* que)
{
    return que->data[0];
}

void free_que(queue* que)
{
    if (que == NULL) {
        cout << "链表数据为空!" << endl;
    }
    free(que);
    cout<<"链表已被摧毁!" << endl;
}

int size_que(queue* que)
{
    return que->size;
}

主函数测试

#include "Queue.h"
typedef struct MyStruct
{
	string name;
	int score;
}myS;
int main() {
	queue* que = init_que();
	myS my[5] = { {"zzz",90},{"ggg",88},{"yyy",99},{"ddd",80},{"nnn",85}};
	int i;
	
	for (i = 0;i<MAX_SIZE;i++) {
		push_que(que, &my[i]);
	}
	cout<<"队列的大小:"<<size_que(que) << endl;
	while (que->size!=0) {
		myS* ty = (myS*)top_que(que);
		cout << "name:" << ty->name << " score: " << ty->score << endl;
		pop_que(que);
	}
	cout << "出队后,队列的大小:" << size_que(que) << endl;
	free_que(que);
	return 0;
}

运行效果

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值