首页 > 编程语言 >[C++/PTA] 队列操作

[C++/PTA] 队列操作

时间:2023-06-14 19:57:32浏览次数:27  
标签:函数 队列 元素 C++ int pop PTA push

题目要求

请实现一个MyQueue类,实现出队,入队,求队列长度.

实现入队函数 void push(int x);
实现出队函数 int pop();
实现求队列长度函数 int size();

输入格式:
每个输入包含1个测试用例。每个测试用例第一行给出一个正整数 n (n <= 10^6) ,接下去n行每行一个数字,表示一种操作:
1 x : 表示从队尾插入x,0<=x<=2^31-1。
2 : 表示队首元素出队。
3 : 表示求队列长度。

输出格式:
对于操作2,若队列为空,则输出 “Invalid”,否则请输出队首元素。 对于操作3,请输出队列长度。
每个输出项最后换行。

输入样例:
5
3
2
1 100
3
2

输出样例:
0
Invalid
1
100

解题思路

代码

静态数组实现

#include <iostream>
using namespace std;

const int MAXSIZE = 100010; //定义静态数组最大长度

class MyQueue { //定义 MyQueue 类
    private:
        int data[MAXSIZE]; //定义一个静态数组 data,用来存储队列元素
        int duilie=0,ren=0; //定义两个变量,表示队列的长度和队首元素位置
    public:
        void push(int x) { //定义 push 函数,将元素 x 加入队列
            data[duilie++] = x; //在数组尾部添加元素,并将队列元素个数加 1
        }
        int pop() { //定义 pop 函数,弹出队首元素并返回该元素值
            if(duilie==ren) //如果队列为空,弹出无效,输出 "Invalid"
                cout<<"Invalid"<<endl;
            else { //否则,弹出队首元素,输出该元素值,并将队列元素个数减 1
                cout<<data[ren++]<<endl;
            }
        }
        int size() { //定义 size 函数,返回队列元素个数(即队列长度)
            cout<<duilie-ren<<endl; //输出队列元素个数
        }
};

int main(int argc, char *argv[]) {
    int i,j,k;
    cin>>i; //输入操作次数
    MyQueue a; //创建 MyQueue 对象 a

    for(j=0;j<i;j++) //进行 i 次操作
    {
        cin>>k; //输入操作类型
        switch(k)
        {
            case 1: //如果操作类型为 1,再输入要加入队列的元素值 x,并调用 push 函数将其加入队列
                int x;
                cin>>x;
                a.push(x);
                break;
            case 2: //如果操作类型为 2,调用 pop 函数弹出队首元素
                a.pop();
                break;
            case 3: //如果操作类型为 3,调用 size 函数返回队列长度
                a.size();
        }
    }
}

注意:
由于静态数组的长度是固定的,因此需要在代码中定义一个常量 MAXSIZE 来表示数组的最大长度。
同时,在 push 函数中,我们使用 data[duilie++] 来将元素加入队列,并在 pop 函数中使用 data[ren++] 来弹出队首元素。

vector容器实现

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector<int> obj; //定义一个 vector 对象 obj,用来存储队列元素
int duilie=0,ren=0; //定义两个变量,表示队列的长度和队首元素位置

class MyQueue { //定义 MyQueue 类
    private:
    public:
    void push(int x) { //定义 push 函数,将元素 x 加入队列
        obj.push_back(x); //在 vector 尾部添加元素
        duilie++; //队列元素个数加 1
    }
    int pop() { //定义 pop 函数,弹出队首元素并返回该元素值
        if(duilie==0) //如果队列为空,弹出无效,输出 "Invalid"
            cout<<"Invalid"<<endl;
        if(duilie!=0) //否则,从队列中删除队首元素,并输出该元素值
        {
            cout<<obj[0]<<endl;
            vector<int>::iterator s = obj.begin(); //定义迭代器 s,将其指向 vector 的起始位置
            obj.erase(s); //在 vector 中删除起始位置的元素
            duilie--; //队列元素个数减 1
        }
    }
    int size() { //定义 size 函数,返回队列元素个数(即队列长度)
        int i;
        for(i=0;i<obj.size();i++)
        {
            ;
        }
        cout<<i<<endl; //输出元素个数 i
    }

};

int main(int argc, char *argv[]) {
    unsigned long long int i,j,k;
    cin>>i; //输入操作次数
    MyQueue a; //创建 MyQueue 对象 a

    for(j=0;j<i;j++) //进行 i 次操作
    {
        cin>>k; //输入操作类型
        switch(k)
        {
            case 1: //如果操作类型为 1,再输入要加入队列的元素值 x,并调用 push 函数将其加入队列
                int x;
                cin>>x;
                a.push(x);
                break;
            case 2: //如果操作类型为 2,调用 pop 函数弹出队首元素
                a.pop();
                break;
            case 3: //如果操作类型为 3,调用 size 函数返回队列长度
                a.size();
        }
    }
}

具体解读

定义了vector<int>类型的对象 obj,用来存储队列中的元素。

MyQueue 是一个类,包含三个成员函数:push() 用来在队尾插入一个元素;pop() 用来删除队首元素;size() 用来返回队列长度。

在 main() 函数中先输入操作次数 i,然后循环执行 i 次操作。每次操作根据输入的操作类型进行相应的处理,包括:添加元素、弹出队首元素、返回队列长度等。

在 push() 函数中,使用 push_back() 在 vector 的尾部添加元素,并将队列元素个数加 1。

在 pop() 函数中,如果队列为空,则输出 "Invalid",否则从队首弹出一个元素,输出该元素值,并将队列元素个数减 1。在这里使用了迭代器进行 vector 的删除操作。

在 size() 函数中,使用迭代器遍历整个 vector,计算其中元素的个数并输出

总结

该题考察队列的基本概念和实现方式;

vector 容器的定义、操作和迭代器的使用;

静态数组的定义和使用,以及队列的模拟实现。

我是秋说,我们下次见。

标签:函数,队列,元素,C++,int,pop,PTA,push
From: https://www.cnblogs.com/qiushuo/p/17481200.html

相关文章

  • [C++/PTA] 表彰优秀学生(多态)
    题目要求学期结束,班主任决定表彰一批学生,已知该班学生数在6至50人之间,有三类学生:普通生,特招运动员,学科专长生,其中学科专长生不超过5人。主函数根据输入的信息,相应建立GroupA,GroupB,GroupC类对象。GroupA类是普通生,有2门课程的成绩(均为不超过100的非负整数);GroupB类是特招运......
  • [C++/PTA] 2017Final进位与借位
    题目要求凤湖小学二年级的陈老师吃惊地发现班上的同学竟然可以分成三类,一类总是可以正确地完成三位整数加减法(GroupA);一类总是可以正确地完成三位整数的加法,但对于减法运算来说,总是忘记借位的处理(GroupB);剩下的人总是忘记加法的进位,也总是忘记减法的借位(GroupC)。现在请给出......
  • [C++] 什么是vertor容器?
    基本概念C++中的vector是一种顺序容器,是一个封装了动态大小数组的顺序容器,可以存放任意类型的数据。vector可以随着元素的加入自动扩充其大小,并且支持在中间插入或删除元素。vector的声明方式为:vector<元素类型>数组名;例如,声明一个储存整数的vector变量可以这样写:......
  • [C++/PTA] 虚函数的应用
    题目要求补充下列代码,使得程序的输出为:A:3A:15B:53155类和函数接口定义:参见裁判测试程序样例中的类和函数接口。裁判测试程序样例:#include<iostream>usingnamespacestd;classCMyClassA{intval;public:CMyClassA(int);voidvirtualprint();......
  • [C++/PTA] 学生成绩快速录入
    题目要求现在需要录入一批学生的成绩(学号,成绩)。其中学号是正整数,并且录入时,后录入学生的学号会比前面的学号大;成绩分两等,通过(Pass,录入时用1代表),不通过(Fail,录入时用0代表)。由于很多学号都是相邻的,并且学号相邻的学生成绩常常相同。所以在录入时,适当地加了速。如果当前学生......
  • [C++/PTA] 我的支付宝和余额宝
    题目要求支付宝AliPay和余额宝AliFund是一对好兄弟,他们来自同一个父类Account。已知类Account是支付宝AliPay和余额宝AliFund的虚基类,包括两个protected成员数据:longID;//账号stringname;//用户名支付宝AliPay是类Account的保护派生类,包括两个新增protected成员数据:double......
  • rocketMQ消息队列简介及其实例
    一、RocketMQ核心的四大组件:Producer:就是消息生产者,可以集群部署。它会先和NameServer集群中的随机一台建立长连接,得知当前要发送的Topic存在哪台BrokerMaster上,然后再与其建立长连接,支持多种负载平衡模式发送消息。Consumer:消息消费者,也可以集群部署。它也会先和NameSe......
  • C/C++中的变长结构体
    1.问题来源首先看下如下的一段代码:#include<stdlib.h>#include<stdio.h>#include<string.h>#defineMAX_LEN1024typedefstructKDtree{doubledata[MAX_LEN];//数据intdim;//选择的维度structKDtree*left;//左子树structKDtree*right;......
  • C/C++——排序
    在C/C++中的排序,使用到的函数主要有:sort()qsort()下面详细分析sort()函数和qsort()函数。1、sort()函数sort()是STL中提供的算法,头文件为:#include<algorithm>usingnamespacestd;函数原型如下:template<classRandomAccessIterator>voidsort(RandomAccessIteratorfirst,Ran......
  • C/C++——map的基本操作总结
    标准库map类型是一种以键-值(key-value)存储的数据类型。以下分别从以下的几个方面总结:map对象的定义和初始化map对象的基本操作,主要包括添加元素,遍历等1、pair类型1.1、pair类型的定义和初始化pair类型是在有文件utility中定义的,pair类型包含了两个数据值,通常有以下的一些定义和初......