看到了大神的代码。理解了好久。。。真是差距。

题意:给出m, p, a, b,然后xi满足已下两个公式, 求 xp1 + xp2 +...+ xp的最大值。

1、-1/sqrt(a) <= xi <= sqrt(a); (a>0)

2、x1+x2+...+xm = b*sqrt(a);

注意:p为偶数。

解题思路:因为p为偶数,所以sqrt(a)和-1/sqrt(a)的p次方都为正数且sqrt(a) > 1/sqrt(a).所以贪心思想时尽量先取sqrt(a);当已经取的xi的和大于b*sqrt(a)时,再取(-1/sqrt(a))抵消多出的sqrt(a)。

为了简便计算同时减少sqrt()带来的误差。可以现将2式左右同乘以sqrt(a)。

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
int main(){
int m, p, a, b;
while(~scanf("%d%d%d%d", &m, &p, &a, &b)) {
int l = , r = ; //l, r分别代表-1/sqrt(a)与sqrt(a)的数目
int sum = a * b;
for(int i = ; i < m; i++) { //注意最后一个数不要考虑
if(sum >= a) {
r++;
sum -= a; //xi已经取定sqrt(a)后,sum记得更新
}
else {
l++;
sum++;
}
}
double ans = l / pow(sqrt(a), p) + r * pow (sqrt(a), p);
ans += pow(sum/sqrt(a), p); //记得要除掉之前乘的sqrt(a);
printf("%d\n", (int)(ans + 0.5));
}
return ;
}

最新文章

  1. 软件工程(FZU2015)赛季得分榜,第一回合
  2. json中$ref对象重复引用问题
  3. Think different
  4. Android——什么是3G
  5. 课堂所讲整理:HTML--8Window.document对象
  6. oracle 笔记
  7. 在centos 6.4下安装opencv 2.3.1
  8. iOS开发Block的使用
  9. C#通过ODAC访问Oracle12c
  10. 自定义JSP标签实现语言国际化(类似struts text标签),并同时支持图片、JS文件国际化
  11. DataTable转换为LIST
  12. docker 指定容器名字
  13. Hadoop 相关问题
  14. 单源最短路径问题-Dijkstra算法
  15. Promise的一点感悟~
  16. SQL结构化查询语句
  17. xhprof 运行结果名词解释
  18. 分布式环境中,模块数据交互协议分析 (百度brpc)
  19. (转载)centos7启用端口
  20. C++ tinyXml直接解析XML字符串

热门文章

  1. thymeleaf的url属性
  2. WEB安全之威胁解析
  3. 进程控制块PCB学习
  4. 关于 jquery cookie的用法
  5. jQuery 源码解析二:jQuery.fn.extend=jQuery.extend 方法探究
  6. sql,mybatis,javascript分页功能的实现
  7. oracle中的数据读取与查找
  8. 汇编语言(学习笔记----寄存器CPU互作原理)
  9. C#操作Word (1)Word对象模型
  10. Hibernate征途(七)之复合主键映射和集合映射