【二分】POJ 2109
来源:互联网 发布:fastreport 数据分栏 编辑:程序博客网 时间:2024/06/04 18:36
谁骗我这是贪心TT
大概就是求k的n次方等于p时的k(k到10^9),由于,p的数据到了10^101,n到200,所以直接算估计T ??
反正看完想到二分,其实数据要是再大点估计我这个二分不行。
网上有三种思路:
1、很自然的,因为觉得数据很大,会去想高精度(可以自己想,或者pow直接double数据还是挺小的)。然后加二分猜数。
2、于是想到转换数学运算:指对互化。用double存,但是double 精确位只有6—7。而没有logx Y,只有先转化为以e为底的对数。用lognP=logn/logP。用两次函数,
精确度不能满足要求。
3、换思路:k^n=p,则p^(1/n)=k。且函数可以直接用pow(x,y)去求x^y。 PS:double精确数值只到16、17的样子,总之慎用。
类型 长度 (bit) 有效数字 绝对值范围
float 32 6~7 10^(-37) ~ 10^38
double 64 15~16 10^(-307) ~10^308
long double 128 18~19 10^(-4931) ~ 10 ^ 4932
//简单法#include<stdio.h>#include<cmath>int main(){ double n,p; while(scanf("%lf%lf",&n,&p)!=EOF) { printf("%.0f\n",pow(p,1/n)); } return 0;}//然而也可以二分,试着敲下。#include <stdio.h>#include <string.h>#include <math.h>#include <stdlib.h> // 取绝对值#include <iostream>#include <algorithm>#include <stack>#include <queue> //priority_queue<int>#include <vector>#include <map>#include <set>#include <utility> //pair类或者 typedef pair<int ,int>P;#define LL long long#define CAN(a,b) memset(a,b,sizeof(a)) //大数 memset(a,0x7f,sizeof(a));#define MAX_Nconst int INF = 0x3f3f3f3f;using namespace std;LL binary(double n,double p){ LL right,left,mid; double ans; right = 10000000002; left = 0; while(left<=right) { mid = (left+right)/2; ans = pow(mid,n); if(ans == p) return mid; else { if(ans<p) left = mid+1; else right = mid; } }}int main(){ double n,p; while(scanf("%lf%lf",&n,&p)!=EOF) { printf("%lld\n",binary(n,p)); }return 0;}
0 0
- 【二分】POJ 2109
- poj 2109 二分+大数乘法
- poj 2109 高精度幂和二分查找
- 【二分答案】POJ-2109 Power of Cryptography
- poj (3343)二分匹配+二分
- POJ 3233 二分二分矩阵
- poj 3685 二分套二分
- poj 3685 二分套二分
- POJ 二分算法
- POJ 3258 二分算法
- poj 2060 二分匹配
- poj 3273 (二分)
- poj 3273(二分。。。很水。。。。)
- poj 3258(二分。。。)
- poj 1693 二分图
- POJ 3122 Pie 二分
- poj 3258 二分 过河
- POJ 3122 Pie 二分
- 安卓,让edittext随手指移动而改变位置
- Response.Redirect()使用技巧
- 杭电ACM1181——变形课
- linux下解压命令大全
- CentOS 7打开NTF文件
- 【二分】POJ 2109
- 用java语言用sort方法实现groupby分组
- 在高配置笔记本式上使用workstation来搭建cloudstack4.3+kvm环境
- JavaScript 前端神器avalonJS入门
- MyBatis Geneator 详解
- android学习 -- 短信发送器
- OpenCV中cvFindContours函数
- Android 深入理解Android中的自定义属性
- Android RelativeLayout属性大全(中文解释)