Acwing周赛记录

本文介绍了两道编程题目,一是寻找两个数对中的公共数,利用简单比较解决;二是计算让奶牛贝茜平均成绩达到5所需的最少修改次数,涉及贪心算法和排序。
摘要由CSDN通过智能技术生成
很难得参加一次周赛hhhhh这次参加的是第144场周赛,一共有三道题

AcWing 5473. 简单数对推理  

 给定两个整数数对,每个数对都包含两个 1∼9 之间的不同整数。

这两个数对恰好包含一个公共数,即恰好有一个整数同时包含于这两个数对。

给定这两个数对,请你找到这个公共数。

输入格式

共两行,每行包含两个 1∼9 之间的不同整数,表示一个数对。

输出格式

一个整数,表示公共数。

数据范围

所有测试点满足,输入整数均在 [1,9]范围内,且保证两个数对恰好包含一个公共数。

输入样例:
1 2
1 3
输出样例:
1

 这道题比较简单哈直接看题解:

#include<bits/stdc++.h>
using namespace std;
int main(){
	int a[3],b[3];
	cin>>a[0]>>a[1];
	cin>>b[0]>>b[1];
	if(a[0]==b[1]||a[1]==b[1]) cout<<b[1]<<endl;
	else if(a[0]==b[0]||a[1]==b[0]) cout<<b[0]<<endl;

	return 0;
}

  5474. 平均成绩

奶牛贝茜刚刚完成了自己的期末测试。

它一共考了 n个科目,每个科目都将获得一个 2∼5之间的整数分数。

贝茜是一头严于律己的奶牛,它希望自己的各科平均分(总分数除以 n)在四舍五入到最接近的整数后,能恰好达到 5。

为了达成这一目的,它可以侵入学校的成绩系统,修改掉若干个科目(也可以完全不修改)的成绩,凡是被修改的科目,都会被它直接改成 5 分。

贝茜是一头谨慎的奶牛,它希望在平均成绩达到期望的前提下,修改成绩的科目尽可能少,从而减少被其他牛发现的可能。

请你计算,它至少需要修改多少个科目的成绩,才能使得平均成绩达到期望。

输入格式

第一行包含一个整数 n。

第二行包含 n个 [2,5] 范围内的整数,表示贝茜的各科成绩。

输出格式

一个整数,表示最少所需的修改成绩的科目数量。

数据范围

前 6个测试点满足 1≤n≤5
所有测试点满足 1≤n≤100。

输入样例1:
3
4 4 4
输出样例1:
2
输入样例2:
4
5 4 5 5
输出样例2:
0
输入样例3:
4
5 3 3 5
输出样例3:
1

   题目解析:

(1)这里用到的四舍五入的公式是这样子的:

(2) 总分需要满足什么条件?
假设sum为平均数,结合(1)中的式子有:

展开可得:

化简得到:

所以这是一个贪心问题, 当单次修改的分数的增长值越多,需要修改的次数越少,算法复杂度为 O(n)

#include<bits/stdc++.h>
using namespace std;
const int N=101;
int q[N];
int main(){
	int n,sum=0;
	int flag=0;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>q[i];
		sum+=q[i];
	}
	sort(q+1,q+n+1); 
	int t = (n * 9 + 1) / 2;
    int res = 0;
    for (int i = 1; i <= n && sum < t; i++ )
    {
        sum += 5 - q[i];
        flag ++ ;
    }
	cout<<flag<<endl;
	
	return 0; 
} 

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值