【华为机试】求解立方根
2017-07-30 17:34
204 查看
题目描述
•计算一个数字的立方根,不使用库函数
详细描述:
输入描述:
待求解参数 double类型
输出描述:
输入参数的立方根 也是double类型
示例1
输入
216
输出
6.0
分析:用的二分法,更快些,但题目还是有点问题的,因为结果要求保留一位小数,题目中没有说明。
•计算一个数字的立方根,不使用库函数
详细描述:
输入描述:
待求解参数 double类型
输出描述:
输入参数的立方根 也是double类型
示例1
输入
216
输出
6.0
分析:用的二分法,更快些,但题目还是有点问题的,因为结果要求保留一位小数,题目中没有说明。
#include<iostream> #include <cmath> //floor()函数要用到此头文件; using namespace std; inline double getCubeRoot(double a){ bool iszheng=true; if(a<0) {a*=-1; iszheng=false;} //判断正负 double l=0.0,r=a,temp; while(l<r){ temp=(l+r)/2.0; if(temp*temp*temp>a) r=temp; else if(abs(temp*temp*temp-a)<0.01) break; else l=temp; } if(iszheng) return temp; else return -1*temp; } int main(){ double a; while(cin>>a){ double res=getCubeRoot(a); printf("%.1f\n",res); //cout<<floor(res*10.00f+0.5)/10.00f<<endl; 保留1位小数; } return 0; }
相关文章推荐
- 华为OJ1964-求解立方根(牛顿迭代法)
- 华为oj之求解立方根
- 【华为oj】求解立方根
- 【华为OJ】求解立方根
- 华为OJ(求解立方根)
- 华为OJ——求解立方根
- 华为OJ题目(十五):求解立方根
- 华为OJ 初级:求解立方根
- 华为oj求解立方根
- 华为OJ平台——求解立方根
- 【华为OJ】【066-求解立方根】
- 华为oj初级 求解立方根
- 【华为 OJ 】求解立方根
- 华为OJ1964-求解立方根(牛顿迭代法)
- 怎样过华为机试
- 华为机试:将字符串里第一次出现的字符输出,重复出现的不显示
- 2014华为机试试题1——反转相加(2013.09.11)
- 华为机试(仿LISP字符串运算)
- 华为oj 字符逆序&&求解立方根&&最小公倍数
- 华为机试:星期几的问题