[转]安徽省小学组省赛2015年第一题 糖果甜度(C++) – BlueCity的小窝
bluecity
博主
BlueCity的小窝
[转]安徽省小学组省赛2015年第一题 糖果甜度(C++)

表示曾经做过。。。
转载自:www.cnblogs.com/zbyrainbow/p/8474401.html
作者:暄妍
我发现,在网上找不到关于安徽省小学组的题解(甚至是题目),因此,我准备把我做过的安徽省小学组的题解上传,供大家参考。

1.糖果甜度(candy)
卡卡西是一个奇幻小说迷,一直憧憬着自己有一天能变成超人,为正义而战。有一天,她放学回家,路过熟悉的糖果店,发现糖果店店员闷闷不乐的样子,正义的卡卡西赶紧上前询问,了解原因。原来贪婪的店长近期为了节省开支,减少
店员,想出题进行员工考核,到期答不出考题的店员就要被解聘。考题是这样的:
在一堆甜度不同的 n 个糖果中,假设只能吃 k 个糖果,请问能吃到的最大甜度之
和是多少。卡卡西冲着店员自信的一笑,拍拍胸脯说:“放心吧,我来帮你解出
这道题,你一定不会被解聘的!”聪明的小朋友们,你们知道如何解出这道题,
帮助店员度过难关吗?

输入:输入数据有两行。第一行有两个数,分别表示糖果的总个数 n 和能吃的
糖果个数 k;第二行有 n个数,用空格分开,分别表示每个糖果的甜度。
输出:能吃到的最大甜度之和。

样例: 输入:(candy.in) 5 2 6 2 5 1 8 输出:(candy.out) 14 样例解释:先吃甜度为 8 的糖,再吃甜度为 6 的糖,甜度之和为 14。

数据范围:0<n≤10000,0≤k≤1000,0<每个糖果的甜度≤100

本题思路:

这可谓是一道大水题啊。直接排序,不过是逆序排序哦,这可能就是出题人想考的吧。接着,累加前k位数字,输出总和就可以了。下面附上本蒟蒻的代码。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
int cmp(int a,int b)
{
 return a>b;
}
int main()
{
 int n,k,sum=0,temp=0;
 cin>>n>>k;
 int a[n];
 for (int i=0;i<n;i++)
 cin>>a[i];
 sort(a,a+n,cmp);
 for (int i=0;i<k;i++)
 sum=sum+a[i];
 cout<<sum<<endl;
 return 0;
}

 

作者:暄妍 博客:http://www.cnblogs.com/zbyrainbow/

本文版权归作者(暄妍)和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

赞赏
转载自:www.cnblogs.com/zbyrainbow/p/8474401.html

欢迎来到Bluecity的博客~

                没有标签 这很BlueCity
首页 » 未分类 » [转]安徽省小学组省赛2015年第一题 糖果甜度(C++)

发表评论

textsms
account_circle
email

BlueCity的小窝

[转]安徽省小学组省赛2015年第一题 糖果甜度(C++)
表示曾经做过。。。 转载自:www.cnblogs.com/zbyrainbow/p/8474401.html 作者:暄妍 我发现,在网上找不到关于安徽省小学组的题解(甚至是题目),因此,我准备把我做过的安徽省小学…
扫描二维码继续阅读
2018-03-25