ACM大一练习赛-第三场------H - 玻色-爱因斯坦凝聚态《二分查找》

H - 玻色-爱因斯坦凝聚态

Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d
& %I64u

Submit Status

Description

Now, here is a fuction:

F(x) = 6 * x^7+8*x^6+7*x^3+5*x^2-y*x (0 <= x <=100)

Can you find the minimum value when x is between 0 and 100.

Input

The first line of the input contains an integer T(1<=T<=100) which means the number of test cases. Then T lines follow, each line has only one real numbers Y.(0 < Y <1e10)

Output

Just the minimum value (accurate up to 4 decimal places),when x is between 0 and 100.

Sample Input

2
100
200 

Sample Output



         -74.4291
-178.8534 

思路:

因为它这个方程是确定的,题上是让求这个方程的最小值,求导后我们发现,这个倒数是递增的,而且这个方程一开始的倒数是负数,它在导函数为0的时候它能够取到最小值,所以我们要通过二分查找的方法,在x中查找能够使导函数为0的点(因为这个函数是递增函数,所以能够用二分查找),然后将找到的x的值带到函数的方程式里面,就是要求的最小值了!首先不要去盲目的进行二分查找,因为用int型的变量内存是有要求的,所以 首先先将x的范围尽量的缩小,刚开始的时候我也是想将x在0~100的范围内查找有没有使导函数为0的点,谁知道超内存,所以我就去想办法将42*N*N*N*N*N*N+48*N*N*N*N*N+21*N*N+10*N的值取最大的时候比y的最大的值大一点,且不超内存,这样任意的y值都能找到使导函数为0的点,还不会超内存,就能够进行我们一般的做题思路了!

代码:

#include <stdio.h>
#include <string.h>
#include <queue>
#include <iostream>
#include <map>
#include <algorithm>
using namespace std;
double y;
double f(double N)
{
	return 42*N*N*N*N*N*N+48*N*N*N*N*N+21*N*N+10*N;
}
double erfen(double left,double right)
{
	double mid;
	while(right-left>1e-7)
	{
		mid=(right+left)/2;
		if(f(mid)-y<1e-7)
		{
			left=mid;
		}
		else
		{
			right=mid;
		}
	}
	return right;
}
int main()
{
	int T;
	scanf("%d",&T);
	while(T--)
	{
		scanf("%lf",&y);
		double t=erfen(0.0,18.0);
		double b=6*t*t*t*t*t*t*t+8*t*t*t*t*t*t+7*t*t*t+5*t*t-y*t;
		printf("%.4lf\n",b);
	}
	return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-09 02:20:30

ACM大一练习赛-第三场------H - 玻色-爱因斯坦凝聚态《二分查找》的相关文章

ACM大一练习赛-第三场——A - 海森堡不确定原理

A - 海森堡不确定原理 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Description 给一个N位的正整数,该数不包含前导0,先让你调整其中每个数字的位置,得到另一个n位的数,并且使得这个数越小越好,而且这个数不能包含前导0.比如543210可以变成102345,而12345保持不变才是最优结果. Input 第一行一个整数T(T<=100),表示有

ACM大一练习赛-第三场------C - 薛定谔的猫《打表枚举的方法》

C - 薛定谔的猫 Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%lld & %llu Submit Status Description Edward, a poor copy typist, is a user of the Dvorak Layout. But now he has only a QWERTY Keyboard with a broken Caps Lock key, so Edward ne

OCAC暑期比赛第三场 H题 01字符串 题解

01字符串原题链接:http://codeforces.com/problemset/problem/165/C[题目描述]一个字符串被称为“01字符串”当且仅当它只包含字符“0”和“1”.我们从字符串 s 中取出连续的一段组成的非空字符串就是 s 的子串.比如,"010" 有6个子串:"0", "1", "0", "01", "10", "010".一个字符串的两个

2014多校第三场1005 || HDU 4891 The Great Pan(模拟)

题目链接 题意 : 给你n行字符串,问你有多少种理解方式.有两大类的理解 (1){A|B|C|D|...}代表着理解方式可以是A,可以是B或C或者D. (2)$blah blah$,在$$这两个符号中间,如果是不连续的空格的那个位置就有2种理解方式,可以理解为没有空格也可以理解为有空格.如果有连续N个空格的位置,那里就有N+1种理解方式. 最后所有的理解方式相乘,数据保证$一定与$匹配,{一定与匹配},不会有任何嵌套,类似{$$}或者{{}}或者${}$这种情况都不会出现,也不会有{$}这种情况

2018 HDU多校第三场赛后补题

2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube 题意: 在画布上画一个三维立方体. 题解: 模拟即可. 代码: #include <bits/stdc++.h> using namespace std; int a, b, c, R, C; char g[505][505]; int main () { int T; cin >>

题解报告(CDUT暑期集训——第三场)

题解报告(CDUT暑期集训--第三场) A - Problem A. Ascending Rating HDU - 6319 思路:单调队列板子题?(但是弱的一批的我还是不会用(有空补上 用的滑动窗口算法 按着题解的从后往前做(ps:菜是原罪 AC代码 #include<stdio.h> #include<iostream> #include<math.h> #include<algorithm> #include<string.h> #incl

最近打的三场比赛的总结

10.25 上午 省常中模拟赛 比赛题目刚发下来,看到出题人之后我就变得紧张起来,因为暑假的时候也做过一份他出的题,题目难到连全场最高分也不过 100 多分,所以又一次做到他出的题难免有些心理阴影. 这种心态直接导致了我在第一题上的失误.由于在心里认为这场模拟赛的难度应该较高,导致我对于第一题几乎不假思索就认为是动规,而根本没有往更简单的方向去想.我一开始想到的是区间动规,但是发现只能拿 50 分,想了一会儿还是没什么思路,于是先把区间动规打好然后打第二题. 第二题是一道比较不错的题,但是由于强

2014 HDU多校弟八场H题 【找规律把】

看了解题报告,发现看不懂 QAQ 比较简单的解释是这样的: 可以先暴力下达标,然后会发现当前数 和 上一个数 的差值是一个 固定值, 而且等于当前数与i(第i个数)的商, 于是没有规律的部分暴力解决,有规律的套公式 //#pragma comment(linker, "/STACK:16777216") //for c++ Compiler #include <stdio.h> #include <iostream> #include <cstring&g

计蒜之道2015程序设计大赛初赛第三场——腾讯手机地图

计蒜之道2015程序设计大赛初赛第三场——腾讯手机地图 (一)题面 腾讯手机地图的定位功能用到了用户手机的多种信号,这其中有的信号的作用范围近,有的信号作用的范围则远一些.有的信号相对于用户在不同的方位强度是不同的,有的则是在任何一个方向上信号强度都一致的. 已知用户面向北方拿着自己的手机,在不同方位的各种信号覆盖区域可以被抽象成以用户为圆心的一系列扇形.已知每个扇形的半径 r,和每个扇形的两条边相对于正东方向的夹角度数.每个信号覆盖区域抽象出的扇形都可以通过从第一条边逆时针旋转到第二条边画出.