STL:常用排序算法

在这里插入图片描述
在这里插入图片描述

class Greater
{
public:
	bool operator()(int val1,int val2)
	{
		return val1 > val2;
	}
};

class Pr
{
public:
	void operator()(int val)
	{
		cout << val << " " ;
	}
};


void test01()
{
	vector<int>v1;
	
	v1.push_back(2);
	v1.push_back(1);
	v1.push_back(4);
	v1.push_back(2);

	sort(v1.begin(), v1.end(),Greater());//降序
	//sort(v1.begin(), v1.end(), greater<int>());//降序
	for_each(v1.begin(), v1.end(), Pr());
	cout << endl;
}

在这里插入图片描述

class Pr
{
public:
	void operator()(int val)
	{
		cout << val << " " ;
	}
};


void test01()
{
	vector<int>v1;
	
	v1.push_back(1);
	v1.push_back(2);
	v1.push_back(3);
	v1.push_back(4);

	random_shuffle(v1.begin(), v1.end());
	for_each(v1.begin(), v1.end(), Pr());
	cout << endl;//1 2 4 3 不加随机种子时每次顺序都一样

}

在这里插入图片描述

class Pr
{
public:
	void operator()(int val)
	{
		cout << val << " " ;
	}
};


void test01()
{
	vector<int>v1;
	
	v1.push_back(1);
	v1.push_back(2);
	v1.push_back(3);
	v1.push_back(4);

	vector<int>v2;

	v2.push_back(5);
	v2.push_back(6);
	v2.push_back(7);
	v2.push_back(8);

	vector<int>vTarget;//目标容器
	vTarget.resize(v1.size() + v2.size());//分配空间

	merge(v1.begin(), v1.end(), v2.begin(), v2.end(), vTarget.begin());
	for_each(vTarget.begin(), vTarget.end(), Pr());
	cout << endl;//1 2 3 4 5 6 7 8

}

注意:v1和v2的升降顺序也要相同

在这里插入图片描述


class Pr
{
public:
	void operator()(int val)
	{
		cout << val << " " ;
	}
};


void test01()
{
	vector<int>v1;
	
	v1.push_back(1);
	v1.push_back(2);
	v1.push_back(3);
	v1.push_back(4);

	
	cout << "反转前" << endl;
	for_each(v1.begin(), v1.end(), Pr());
	cout << endl;//1 2 3 4

	cout << "反转后" << endl;
	reverse(v1.begin(), v1.end());
	for_each(v1.begin(), v1.end(), Pr());
	cout << endl;//4 3 2 1

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值