C++ STL编程 vector空间预留、vector高效删除、vector数据排序、vector代码练习

vector空间预留,作用是避免申请每次申请内存,提高运行效率。

对应的接口是 vector.reverse()

vector的高效删除,对应的代码见下,一个时间复杂度是n,一个时间复杂度是1

cpp 复制代码
#include<iostream>
#include<vector>

using namespace std;

void removeal(vector<int>& v, int index) {
	v.erase(v.begin() + index); // 时间复杂度是n
}

void remove2(vector<int>& v, int index) {
	swap(v[index], v.back()); // 时间复杂度为1
	v.pop_back();
}

void printVector(vector<int>& v) {
	for (int i = 0; i < v.size(); ++i) {
		cout << v[i] << " ";
	}
	cout << endl;
}

int main() {
	vector<int> v;
	cout << "r1: ";
	for (int i = 0; i < 150006; ++i) {
		v.push_back(i);
	}

	for (int i = 0; i < 150000; ++i) {
		removeal(v, 4);
	}	
	cout << "r1~end";
	//printVector(v);

	cout << "r2: ";
	for (int i = 0; i < 150006; ++i) {
		v.push_back(i);
	}

	for (int i = 0; i < 150000; ++i) {
		remove2(v, 4);
	}

	cout << "r2~end()"; 
	//printVector(v);
	return 0;
}

vector数据排序,代码见下:

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<vector>

using namespace std;

void printVector(const vector<int>& v) {
	for (int i = 0; i < v.size(); ++i) {
		cout << v[i] << " ";
	}
	cout << endl;
}

bool cmp(int a, int b) {
	return a > b;
}

int main() {
	vector<int> v = { 2, 3, 9, 5, 6, 7 };
	sort(v.begin(), v.end(), cmp);// 这个是默认从小到大排序,可以加个cmp就可以告诉他咋排序
	printVector(v);
}

代码练习,对应力扣,数组串联,代码见下

cpp 复制代码
class Solution {
public:
    vector<int> getConcatenation(vector<int>& nums) {
        int n = nums.size();
        vector<int> ans(nums);
        ans.resize(2*n);
        for(int i=0; i<n; ++i){
            ans[i+n] = nums[i];
        }
        return ans;
    }
};
相关推荐
优雅的潮叭2 小时前
c++ 学习笔记之 chrono库
c++·笔记·学习
星火开发设计2 小时前
C++ 数组:一维数组的定义、遍历与常见操作
java·开发语言·数据结构·c++·学习·数组·知识
月挽清风2 小时前
代码随想录第七天:
数据结构·c++·算法
TTGGGFF2 小时前
控制系统建模仿真(一):掌握控制系统设计的 MAD 流程与 MATLAB 基础运算
开发语言·matlab
2501_944424122 小时前
Flutter for OpenHarmony游戏集合App实战之贪吃蛇食物生成
android·开发语言·flutter·游戏·harmonyos
Lhuu(重开版4 小时前
JS:正则表达式和作用域
开发语言·javascript·正则表达式
点云SLAM4 小时前
C++内存泄漏检测之Windows 专用工具(CRT Debug、Dr.Memory)和Linux 专业工具(ASan 、heaptrack)
linux·c++·windows·asan·dr.memory·c++内存泄漏检测·c++内存管理
仙俊红4 小时前
Java Map 家族核心解析
java·开发语言
浅念-4 小时前
C语言小知识——指针(3)
c语言·开发语言·c++·经验分享·笔记·学习·算法
code_li5 小时前
聊聊支付宝架构
java·开发语言·架构