2024年第十五届蓝桥杯C&C++大学A组--成绩统计

2024年第十五届蓝桥杯C&C++大学A组--成绩统计

题目:

动态规划,

对于该题,考虑动态规划解法,先取前k个人的成绩计算其方差,并将成绩记录在数组中,记录当前均值,设小蓝已检查前i-1个人的成绩,若方差依然大于T,找出离均值最远的一个成绩,若第i个人的成绩距离当前均值更近,则剔除离均值较远的成绩,使得方差变小,若遍历完整个数组均找不到更小的方差,返回-1。

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n, k, T;
vector<int> nums;
vector<int> team;

bool is0()
{
	double mean,val;
	double sum = 0;
	for (auto num : team)
	{
		sum += num;
	}
	mean = sum / k;
	val = 0;
	for (auto num : team)
	{
		val += (num - mean) * (num - mean);
	}
	val /= k;
	if (val < T) 
		return true;
	else 
		return false;
}


int main()
{
	cin >> n >> k >> T;
	int N = n;
	while (N--)
	{
		double temp;
		cin >> temp;
		nums.push_back(temp);
	}
	if (n < k)
	{
		cout << -1;
		return 0;
	}

	double sum = 0;
	for (int i = 0;i < k; i++)
	{
		team.push_back(nums[i]);
		sum += nums[i];
	}
	double mean = sum / k;
	if (is0())
	{
		cout << k;
		return 0;
	}
	for (int i = k; i < nums.size(); ++i)
	{
		double sub = 0;
		int x = -1;
		for (int j = 0; j < team.size(); ++j)
		{
			if (abs(team[j] - mean) > sub)//找出距离平均值最远的值和下标
			{
				sub = abs(team[j] - mean);
				x = j;
			}
		}
		if (x != -1 && sub > abs(nums[i] - mean))
			team[x] = nums[i];
		if (is0())
		{
			cout << i + 1;
			return 0;
		}
		return -1;
	}
	return 0;
}
相关推荐
浅念-2 分钟前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
WeiXiao_Hyy3 分钟前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
User_芊芊君子9 分钟前
CANN010:PyASC Python编程接口—简化AI算子开发的Python框架
开发语言·人工智能·python
小羊不会打字10 分钟前
CANN 生态中的跨框架兼容桥梁:`onnx-adapter` 项目实现无缝模型迁移
c++·深度学习
Max_uuc19 分钟前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
故事不长丨20 分钟前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
近津薪荼21 分钟前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
牵牛老人23 分钟前
【Qt 开发后台服务避坑指南:从库存管理系统开发出现的问题来看后台开发常见问题与解决方案】
开发语言·qt·系统架构
froginwe1131 分钟前
Python3与MySQL的连接:使用mysql-connector
开发语言
灵感菇_1 小时前
Java HashMap全面解析
java·开发语言