NOI题解(1.10编程基础之简单排序)

这篇博客主要解析了NOI竞赛中与简单排序相关的题目,包括使用vector存储结构体变量,自定义排序以及冒泡排序和algorithm库中的sort函数。内容涵盖‘谁考了第k名’、‘奇数单增序列’等多个实战问题,通过实例讲解排序算法在不同场景的应用。
摘要由CSDN通过智能技术生成

涉及的知识点:

vector容器存储结构体变量

sort自定义排序

稳定排序:冒泡排序

不稳定排序:algorithm中的sort函数,为不稳定排序

题目地址:http://noi.openjudge.cn/ch0110/


01:谁考了第k名

#include <iostream>
#include <vector>
#include <algorithm>
struct stu
{
	int num;
	float grade;
};
bool compare(const stu* st1,const stu* st2)
{
	return st1->grade>st2->grade;
}

int main()
{
	int n,k;
	std::cin>>n>>k;

	std::vector<stu*> v;
	for(int i=0;i<n;i++)
	{
		stu *student = new stu();
		int num;
		float grade;
		std::cin>>num>>grade;
		student->num = num;
		student->grade = grade;
		v.push_back(student);
	}
	sort(v.begin(),v.end(),compare);

	// for(std::vector<stu*>::iterator it=v.begin();it!=v.end();it++)
	// {
	// 	std::cout<<(*it)->num<<" "<<(*it)->grade<<std::endl; 
	// }

	std::cout<<(*v[k-1]).num<<" "<<(*v[k-1]).grade<<std::endl;
	// std::cout<<v[k-1]->num<<" "<<v[k-1]->grade<<std::endl;//这两种访问方式都可以
	return 0;
}

02:奇数单增序列

#include <iostream>
#include <vector>
#include <algorithm>
int main()
{
	int n;
	std::cin>>n;
	std::vector<int>vc;
	while(n--)
	{
		int num;
		std::cin>>num;
		if(num%2!=0)
			vc.push_back(num);
	}
	sort(vc.begin(),vc.end());
	bool firstF = true;
	for(int i=0;i<vc.size();i++)
	{
		if(firstF)
		{
			std::cout<<vc[i];
			firstF = false;
		}
		else
		{
			std::cout<<","<<vc[i];
		}
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值