C++ vector查改增删操作

初始化

在c++中,vector是一个类模板,当使用模板的时候,我们需要指出编译器应该把类和函数实例化成何种类型。

vector<int> ivec;//vector的元素是int型数据
vector<vector<string>> file;//vector的元素还是是vector对象,这个vector对象的元素是string型数据

默认初始化

vector<T> v1;//v1是一个空vector,它潜在的元素是T类型的,执行默认初始化

拷贝初始化

//针对的是变量
vector<T> v2(v1);//v2中包含v1所有元素的副本
vector<T> v2=v1;//等价于v2(v1),v2中包含有v1所有元素的副本

列表初始化(花括号)

//针对的是变量的元素
vector<T> v3{a,b,c...};//v3包含了初始值个数的元素,每个元素被赋予相应的初始值
vector<T> v3={a,b,c};//等价于上一个

值初始化(小括号)

//针对的是变量的元素数量
//输入的n应该是给构造函数的
vector<T> v4(n,val);//v5中包含着n个重复的,值为val的元素
vector<T> v5(n);//v5包含了n个重复的,默认值的元素

注意,使用花括号进行值初始化时,编译器也能理解

vector<string> v6{"hi"};//列表初始化:v6有一个元素
vector<string> v7("hi");//错误,不可以用元素值来构建vector对象
vector<string> v8{10};//v8有10个默认初始化的元素
vector<string> v9{10,"hi"};//v9有10个值为hi的元素

查找元素

我们可以通过遍历vector,返回所查找元素的下标。

int findElement(vector<int> v, int key){
	// 获取vector的长度。
	int len = v.size();
	for(int i = 0; i < len; i++){
		if(v[i] == key){
			return i;
		}
	}
	return -1;
}

修改元素

直接对应下标指向位置进行修改。

v[1] = v[0];

增加元素

在vector中增加元素包括两种,一种是在尾部增加元素,另一种是在指定位置增加元素。

尾部增加

// 使用push_back()函数
vector<int> v;
for (int i = 0; i < 10; i++)
{
    v.push_back(i);
}

指定位置增加

// 使用insert()函数
// 在v[2]位置插入10
v.insert(v.begin() + 2, 10);

删除元素

在vector中删除元素包括三种,第一种是删除尾部的元素,第二种是删除指定的元素,第三种是删除所有元素。

尾部删除

// 使用pop_back()函数
v.pop_back();

指定位置删除

// 使用erase()函数
// 删除开始位置的元素,并不会回收空间
v.erase(v.begin());
// 删除区间[i,j-1]的元素
v.erase(v.begin() + i, v.end() - j);

删除所有元素

// 使用clear()函数
// 并不会回收空间,但v.size()变成0
v.clear();
C++中,设计一个学生成绩管理系统通常会涉及到一些核心概念,如类和对象、数据结构(如数组或链表)、文件I/O操作以及基本的控制结构。这里是一个简单的概述: 1. 定义学生类(Student):包含属性如姓名(name)、学号(student_id)和成绩(scores)等,并定义相应的方法,比如添加成绩(add_score)、获取总分(get_total_score)等。 ```cpp class Student { public: string name; int student_id; vector<int> scores; void add_score(int new_score); int get_total_score(); }; ``` 2. 存储管理:可以使用数组或动态数据结构(如vector)来存储多个学生对象。如果需要长期存储,也可以考虑使用文件I/O,将学生信息保存到文本文件中。 3. 增(add):允许用户添加新学生或更新现有学生的成绩。例如,可以通过输入界面或命令行接收用户输入。 ```cpp void Student::add_score(int new_score) { scores.push_back(new_score); } ``` 4. 删(delete):删除学生或成绩。可能需要提供方法来根据学号或名称查找并移除。 5. 查(query):提供搜索功能,查找特定学生的信息或按条件筛选(如成绩排名)。 6. 改(modify):允许修改学生信息或成绩。同样,需要提供方法找到对应的记录。 7. 用户界面:为了方便用户交互,可以创建一个控制台程序或图形界面,让使用者选择操作并输入必要的信息。 ```cpp int main() { // 创建学生对象数组或文件对象 // 提供菜单让用户选择操作 // 调用学生类的方法执行相应的操作 return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值