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

C++ vector模板和deque的简单应用

目录

🤔vector模板和deque的简单介绍:

🤔vector和deque的主要不同之处:

🤔今天我们用vector模板和deque模板实现以下简单的功能:

代码实现:

🤔讲解:


🤔vector模板和deque的简单介绍:

vectordeque都是C++ STL(标准模板库)中的容器模板,用于存储和管理数据。它们都提供了可动态调整大小的数组,允许在任何位置插入和删除元素。

🤔vector和deque的主要不同之处:

内部数据结构的实现方式不同:vector使用连续的内存块来存储元素,所以随机访问元素的速度很快,但在插入和删除元素时需要移动后续元素的成本可能比较高。deque则采用了一种双向队列的数据结构,可以在两端快速插入和删除元素,但在随机访问元素时的效率较低。

关于这两个模板的详细介绍可以看以下两篇文章:

C++ vector类成员函数介绍_我是一盘牛肉的博客-CSDN博客

 C++ deque类成员函数介绍_我是一盘牛肉的博客-CSDN博客

🤔今天我们用vector模板和deque模板实现以下简单的功能:

📖1.创建五名选手,放到vector中
📖2.遍历vector容器,取出来每一个选手,执行for循环,把10个评分存储到deque容器中
📖3.sort排序后去除最高分和最低分
📖4.deque容器遍历,累加总分
📖5.获取平均分:

代码实现:

#include<iostream>
#include<vector>
#include<deque>
#include<string>
#include<algorithm>
using namespace std;
class person
{
public:person(string name, int age){m_name = name;m_age = age;}string m_name;int m_age;int score;
};
void test01()
{//完成了创建选手vector<person> persons;for (int i = 0; i < 5; i++){string name;int age;cout << "请输入第"<<i+1<<"位参赛选手的姓名:";cin >> name;cout << "请输入第" << i + 1 << "位参赛选手的年龄:";cin >> age;person* p = new person (name,age);//开始录入分数deque<int>scroes;for (int i = 0; i < 10; i++){int nums = 0;cout << "请输入第" << i + 1 << "位裁判的分数:";cin >> nums;scroes.push_front(nums);}//排序后去除最高分和最低分sort(scroes.begin(), scroes.end());scroes.pop_front();scroes.pop_back();//计算平均值int sums = 0;for (deque<int>::iterator t1 = scroes.begin(); t1 != scroes.end(); t1++){sums = sums + *t1;}int arrage;arrage = sums / 3;p->score = arrage;persons.push_back(*p);	}for (vector<person>::iterator t = persons.begin(); t != persons.end(); t++){cout << "选手姓名" << t->m_name << "选手年龄" << t->m_age << "选手分数" << t->score << endl;}
}
int main()
{test01();
}

🤔讲解:

这段代码使用C++创建了一个选手评分系统。首先,利用person类创建了存储选手信息的vector向量persons,并使用用户输入的信息初始化了person对象并将其存储到向量中。接下来,使用deque双端队列记录了每位参赛选手10次裁判打分,并且去掉最高分和最低分,计算得出该选手的平均分数,将平均分数保存到对应的person对象的score成员变量中。最后,使用迭代器遍历persons向量,输出所有选手的姓名、年龄、成绩。

http://www.lryc.cn/news/89710.html

相关文章:

  • 声明式事务控制
  • cisp pte模拟题
  • Docker容器 和 Kubernetes容器集群管理系统
  • 港联证券|资金疯狂涌入AI,这一板块涨幅超90%!万亿巨头继续狂飙
  • 短视频矩阵系统源码-开源开发php语言搭建
  • PFEA112-20 3BSE050091R20 张力控制器
  • Java springboot+vue生成报纸排版页面的新闻官网
  • Terra-Luna归零一年后:信任重建、加密未来路在何方?
  • Android 12.0 手动安装Persistent app失败的解决方案
  • Unity3D安装:从命令行安装 Unity
  • C++模板(详解)
  • WuThreat身份安全云-TVD每日漏洞情报-2023-05-25
  • android 12.0去掉recovery模式UI页面的选项
  • C++ vector类成员函数介绍
  • 【C++】二叉搜索树Binary Search Tree
  • Hover.css动画库的使用
  • Baumer工业相机堡盟工业相机如何通过文件保存和导入的方式保存和载入相机的各类参数(C#)
  • 封装设计!抽象BasePage,提升WEB自动化测试用例质量和效率
  • c primer plus学习笔记(一)
  • C语言2:说心里话
  • 任务19 简单个人电话号码查询系统
  • day4--链表内指定区间反转
  • HTTP状态码是什么?常用的状态码有什么?
  • 【软件分析/静态分析】学习笔记01——Introduction
  • Java数组
  • 【数据库原理入门】
  • 练习Vue烘培坊项目
  • API测试| 了解API接口测试| API接口测试指南
  • 使用canvas给图片添加水印
  • 栈和队列的概念和实现