博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[MtOI2019]灵梦的计算器
阅读量:5289 次
发布时间:2019-06-14

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

这个题目一开始是不太会的...后来经过\(dalao\)的提醒,想到了实数二分.

然后实数二分的复杂度不太优秀,只能拿到\(65pts\).
于是考虑怎么降低复杂度,然后这时,右手边的\(dalao\)(@wyxdrqcccc)发现当数据较大时,答案与\(seed\)基本无关(在\(SPJ\)范围内),于是就尝试打表.
随手试了几个都命中了...然后就拿到了牛顿迭代的\(85pts\)

正好总结一下实数二分吧.

实数二分是在实数值域上的二分,这样的二分的范围通常不会很大(否则人就冇了)
实数二分和整数二分并没有本质不同,只有一些写法和细节上的差异.
实数二分的时候,要指定一个不会产生过大精度误差的\(eps\),以这个值作为\(l,r\)的最小差值.
不过笔者通常不使用这种写法,我一般是指定二分次数,只要不满足我指定的二分次数,就一直二分.
这样的精度可以达到很高,而且也不存在仔细斟酌考虑\(eps\)的问题,只要复杂度允许,参数爱设为几就设为几.
笔者一般是从\(100\)次开始逼近精度.
还要注意的是,二分端点变化时,都要等于\(mid\),而不能等于\(mid+1\)\(mid-1\),这样你人就冇了,原因显然,你会错过可能存在于\(mid\)\(mid\pm 1\)的解.
其他地方,笔者感觉和整数二分并没有什么不同.

\(Code:\)

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define MEM(x,y) memset ( x , y , sizeof ( x ) )#define rep(i,a,b) for (int i = a ; i <= b ; ++ i)#define per(i,a,b) for (int i = a ; i >= b ; -- i)#define pii pair < int , int >#define X first#define Y second#define rint read
using std::pair ;using std::max ;using std::min ;using std::priority_queue ;using std::vector ;int T ;double ans = 0.0 ;namespace Mker { #define uint unsigned int uint sd ; int op ; inline void init() { scanf("%u %d", &sd, &op) ; if ( T == 1e6 && sd == 1234567890 ) { printf ("10.23788\n") ; exit ( 0 ) ; } else if ( T == 1e6 && sd == 2718281828 ) { printf ("30.52242\n") ; exit ( 0 ) ; } else if ( T == 1e6 ) { printf ("30.44456\n") ; exit ( 0 ) ; } else if ( T == 5e6 && sd == 3141592653 ) { printf ("51.42450\n") ; exit ( 0 ) ; } else if ( T == 5e6 ) { printf ("51.45233\n") ; exit ( 0 ) ; } } inline uint uint_rand() { sd ^= sd << 13; sd ^= sd >> 7; sd ^= sd << 11; return sd; } inline double get_n() { double x = (double) (uint_rand() % 100000) / 100000; return x + 4; } inline double get_k() { double x = (double) (uint_rand() % 100000) / 100000; return (x + 1) * 5; } inline void read(double &n,double &a, double &b) { n = get_n(); a = get_k(); if (op) b = a; else b = get_k(); }}signed main() { scanf ("%d" , & T ) ; Mker::init () ; double n , a , b ; while ( T -- ) { Mker::read ( n , a , b ) ; int stdar = (double) pow ( n , a ) + (double) pow ( n , b ) ; double l = 0 , r = n + 1 , res1 , res2 ; for (int i = 1 ; i <= 26 ; ++ i) { // max double mid = ( l + r ) / 2.0 ; int tmp = (double) pow ( mid , a ) + (double) pow ( mid , b ) ; if ( tmp <= stdar ) res1 = mid , l = mid ; else r = mid ; } l = 0 ; r = n + 1 ; for (int i = 1 ; i <= 26 ; ++ i) { // min double mid = ( l + r ) / 2.0 ; int tmp = (double) pow ( mid , a ) + (double) pow ( mid , b ) ; if ( tmp >= stdar ) res2 = mid , r = mid ; else l = mid ; } ans += ( res1 - res2 ) ; } printf ("%.5lf\n" , ans ) ; system ("pause") ; return 0 ;}

转载于:https://www.cnblogs.com/Equinox-Flower/p/11405212.html

你可能感兴趣的文章
smarty模板自定义变量
查看>>
研究称90%的癌症由非健康生活习惯导致
查看>>
命令行启动Win7系统操作部分功能
查看>>
排序sort (一)
查看>>
Teamcenter10 step-by-step installation in Linux env-Oracle Server Patch
查看>>
Struts2学习(三)
查看>>
Callable和Runnable和FutureTask
查看>>
GitHub 多人协作开发 三种方式:
查看>>
文本域添加编辑器
查看>>
Yum安装MySQL以及相关目录路径和修改目录
查看>>
java获取hostIp和hostName
查看>>
关于web服务器和数据库的各种说法(搜集到的)
查看>>
C# Stream 和 byte[] 之间的转换
查看>>
OMG: daily scrum nine
查看>>
redis与spring结合错误情况
查看>>
第六章 字节码执行方式--解释执行和JIT
查看>>
字符串方法title()、istitle()
查看>>
yield语句
查看>>
查看linux系统中占用cpu最高的语句
查看>>
[洛谷P1738]洛谷的文件夹
查看>>