博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
GTW likes math(简单数学)
阅读量:6183 次
发布时间:2019-06-21

本文共 3134 字,大约阅读时间需要 10 分钟。

GTW likes math

 
 Accepts: 472
 
 Submissions: 2140
 Time Limit: 2000/1000 MS (Java/Others)
 
 Memory Limit: 131072/131072 K (Java/Others)
Problem Description

After attending the class given by Jin Longyu, who is a specially-graded teacher of Mathematics, GTW started to solve problems in a book titled “From Independent Recruitment to Olympiad”. Nevertheless, there are too many problems in the book yet GTW had a sheer number of things to do, such as dawdling away his time with his young girl. Thus, he asked you to solve these problems.

In each problem, you will be given a function whose form is like f(x)=ax ^ 2 + bx + c,f(x)=ax2​​+bx+c. Your assignment is to find the maximum value and the

minimum value in the integer domain [l, r][l,r].

Input

The first line of the input file is an integer TT, indicating the number of test cases. (T\leq 1000T1000)

In the following TT lines, each line indicates a test case, containing 5 integers, a, b, c, l, ra,b,c,l,r. (|a|, |b|, |c|\leq 100, |l|\leq |r|\leq 100a,b,c100,lr100), whose meanings are given above.

Output

In each line of the output file, there should be exactly two integers, maxmax and minmin, indicating the maximum value and the minimum value of the given function in the integer domain [l, r][l,r], respectively, of the test case respectively.

Sample Input
11 1 1 1 3
Sample Output
13 3
Hint
f_1=3,f_2=7,f_3=13,max=13,min=3f1​​=3,f2​​=7,f3​​=13,max=13,min=3
题解:
就让找[l,r]区间ax ^ 2 + bx + c的最大值和最小值;由于没看到integer domain整数域,用三分和暴力wa了几次;
代码:
#include
#include
#include
#include
#include
#include
#include
using namespace std;const int INF=0x3f3f3f3f;#define SI(x) scanf("%d",&x)#define PI(x) printf("%d",x)#define P_ printf(" ")#define T_T while(T--)#define mem(x,y) memset(x,y,sizeof(x))const int MAXN=0x3f3f3f3f;int a,b,c,l,r;int js(int x){ return a*x*x+b*x+c;}/*void sanfen(double l,double r){ double mx,mi,m,mm; double x=l,y=r; while(r-l>=1e-6){ m=(l+r)/2.0; mm=(m+r)/2.0; if(js(m)>=js(mm))r=mm; else l=m; } mx=js(l); l=x;r=y; while(r-l>=1e-6){ m=(l+r)/2.0; mm=(m+r)/2.0; if(js(m)<=js(mm))r=mm; else l=m; } mi=js(l); printf("%.0lf %.0lf\n",mx,mi);}*/int main(){ int T; SI(T); int mi,mx; T_T{ scanf("%d%d%d%d%d",&a,&b,&c,&l,&r); mi=INF;mx=-INF; for(int i=l;i<=r;i++){ mi=min(mi,js(i)); mx=max(mx,js(i)); } printf("%d %d\n",mx,mi); } return 0;}/*#include
#include
#include
#include
#include
#include
#include
using namespace std;const int INF=0x3f3f3f3f;#define SI(x) scanf("%d",&x)#define PI(x) printf("%d",x)#define P_ printf(" ")#define T_T while(T--)#define mem(x,y) memset(x,y,sizeof(x))double a,b,c,l,r;double js(double x){ return a*x*x+b*x+c;}int main(){ int T; SI(T); T_T{ scanf("%lf%lf%lf%lf%lf",&a,&b,&c,&l,&r); double mid=-b/(2*a); double m[3]; m[0]=js(mid); m[1]=js(l);m[2]=js(r); //printf("%lf %lf %lf\n",m[0],m[1],m[2]); if(l<=mid&&mid<=r)printf("%.0lf %.0lf\n",*max_element(m,m+3),*min_element(m,m+3)); else printf("%.0lf %.0lf\n",max(m[1],m[2]),min(m[1],m[2])); } return 0;}*/

  

转载地址:http://afsda.baihongyu.com/

你可能感兴趣的文章
了解你所不知道的SMON功能(四):维护col_usage$字典基表
查看>>
saltstack的安装和初步试用体验
查看>>
wall命令
查看>>
演示针对LVM分区的管理
查看>>
老王学linux-centos6.7RHCS
查看>>
string与CString
查看>>
深入实践Spring Boot1.6 小结
查看>>
为什么会"well-known file is not secure" ?
查看>>
ThinkPHP隐藏index.php的方法汇总【IIS/Apache/Nginx】
查看>>
<转>进程与线程的一个简单解释
查看>>
typescript 学习教程 (1)
查看>>
Hadoop 解除 "Name node is in safe mode"
查看>>
正则表达式
查看>>
字符串处理的练习~
查看>>
一名网工对Linux运维的一次经历
查看>>
jdbc中如何使用classloader
查看>>
在Struts2中方便获得Spring中的Bean方法
查看>>
「ThinkPHP开发者周刊」第2期
查看>>
思达报表工具Style Report基础教程—交叉表
查看>>
H3C笔试题目
查看>>