链接:https://ac.nowcoder.com/acm/contest/358/A
来源:牛客网

题目描述

众所周知,每个人都有自己的rp值(是个非负实数),膜别人可以从别人身上吸取rp值。
然而当你膜别人时,别人也会来膜你,互膜一段时间后,你们就平分了两人原有的rp值,当你膜过一个人之后,你就不能再膜那个人了
出题人发现自己的rp值为x,出题人周围有n个人,第i个人的rp值为a[i]
你要选择膜哪些人和膜人的顺序,使出题人的最终rp值最大

输入描述:

第一行两个数n,x,人数和出题人的初始rp值
第二行n个数,第i个数a[i]表示第i个人的rp值

输出描述:

一行一个数表示出题人的最终rp值(保留三位小数)
示例1

输入

复制

1 0
1

输出

复制

0.500

备注:

数据范围:
n<=100000,a[i]<=100000,x<=100000,(a[i],x都是整数) 题目链接

链接:https://ac.nowcoder.com/acm/contest/358/A
来源:牛客网

题意:中文题面,自行阅读。

思路:

首先把RP值的数组排序一下,

然后扫一边,碰到数值比当前自己的r人品值大的数就去膜。

注意:题目要保留3位小数,是严格的三位,多输出一位都算错的。

细节见代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#define sz(a) int(a.size())
#define all(a) a.begin(), a.end()
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define db(x) cout<<"== "<<x<<" =="<<endl;
using namespace std;
typedef long long ll;
inline void getInt(int* p);
const int maxn=;
const int inf=0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/
int n,x;
double ans=0.00;
int a[maxn];
int main()
{
gg(n);
gg(x);
repd(i,,n)
{
gg(a[i]);
}
ans=1.00*x;
sort(a+,a++n);
repd(i,,n)
{
if(a[i]>ans)
ans=(ans+1.0*a[i])/2.000;
}
printf("%.3lf",ans);
return ;
} inline void getInt(int* p) {
char ch;
do {
ch = getchar();
} while (ch == ' ' || ch == '\n');
if (ch == '-') {
*p = -(getchar() - '');
while ((ch = getchar()) >= '' && ch <= '') {
*p = *p * - ch + '';
}
}
else {
*p = ch - '';
while ((ch = getchar()) >= '' && ch <= '') {
*p = *p * + ch - '';
}
}
}

最新文章

  1. Theano:LSTM源码解析
  2. shell脚本批量调用git命令
  3. 自定义UICollectionViewController之后 如何设置UICollectionView的布局方式
  4. fedora 安装lamp
  5. c#基础学习笔记-----------委托事件
  6. 设计模式23---设计模式之装饰模式(Decorator)(结构型)
  7. 140. Word Break II
  8. PHP利器-WAMPServer
  9. PYTHON调用JENKINS的API来进行CI
  10. 惠普 hpssacli 工具使用
  11. QF——UITableViewCell性能优化(视图复用机制)
  12. c循环程序
  13. Mysql的收获
  14. L1-8 矩阵A乘以B (15 分)
  15. 重装@angular/cli reason: write EPROTO 139955972261696:error:1408F10B:SSL routines:ssl3_get_record:wrong version number:../deps/openssl/openssl/ssl/record/ssl3_record.c:252:
  16. .NET Core开发日志——Dapper与MySQL
  17. Linux下自制回收站
  18. JDBC删除数据实例
  19. Fragment在Activity中跳转,实现类似新闻标题跳转新闻内容功能
  20. (C/C++) STL 標頭檔 algorithm (一)

热门文章

  1. SSM框架—环境搭建(MyEclipse+Tomcat+MAVEN+SVN)
  2. [TC]Total Command显示文件夹大小
  3. 排序算法之快速排序的思想以及Java实现
  4. 一台电脑安装两个JDK
  5. 《Java大学教程》—第9章 软件质量
  6. 【Teradata】tdlocaledef修改默认日期配置
  7. POJ 3970(最小公倍数LCM)
  8. C#自动化操作IE浏览器系列之一打开新的浏览器并导航到百度进行搜索
  9. 基于BeautifulSoup库的HTML内容的查找
  10. ddt框架优化(生成html报告注释内容传变量)