leetcode笔记:Sqrt(x)
2015-12-31 22:56
274 查看
一. 题目描述
Implement int sqrt(int x).
Compute and return the square root of x.
二. 题目分析
该题要求实现求根公式,该题还算是比较简单的,因为只需返回最接近的整数,直接二分法即可。在实现的过程中还是有一些细节的,比如判断条件:
三. 示例代码
一些运行结果:
四. 小结
此题为分治思路的经典题型之一。
Implement int sqrt(int x).
Compute and return the square root of x.
二. 题目分析
该题要求实现求根公式,该题还算是比较简单的,因为只需返回最接近的整数,直接二分法即可。在实现的过程中还是有一些细节的,比如判断条件:
x / mid > mid而不能是
x > mid * mid,因为
mid * mid会导致溢出。
三. 示例代码
[code]#include <iostream> using namespace std; class Solution { public: int sqrt(int x) { if (x == 0 || x == 1) return x; int min = 1, max = x / 2; // 根必在此区间中 // 二分查找 int mid, result; while (min <= max) { mid = min + (max - min) / 2; if (x / mid > mid) { // 根的平方需小于等于x,因此每次须在此处更新根的值 result = mid; min = mid + 1; } else if (x / mid < mid) max = mid - 1; else return mid; } return result; } };
一些运行结果:
四. 小结
此题为分治思路的经典题型之一。
相关文章推荐
- 2015年广工操作系统实验(要求实现图形化界面)
- 用获得送走2015——生产实习总结
- 《挑战程序设计竞赛》3.1.5 二分搜索-其它 POJ1759 3484
- 8.zabbix学习笔记:zabbix实现网络发现
- ContentProvider
- 《挑战程序设计竞赛》3.1.4 二分搜索-最小化第k大的值 POJ2010 3662(2)
- discuz mysqli_connect() 不支持 advice_mysqli_connect
- Nginx Location配置总结
- discuz mysqli_connect() 不支持 advice_mysqli_connect
- java.lang.illegalargumentexception view android.widget.listview is not a sliding drawer
- 欢送2015,喜迎2016
- 网络营销大数据实操七步走
- 深入学习js中的json
- New Year's resolution for 2016
- 2015年小结。
- 敏感词测试 检查单 2015-12-31-01 这个博客不能用了。
- https原理与调试文章集合
- 开始学习一个指令 directive 并了解指令的意义
- Java虚拟机参数详解
- vb.net动态建库之CodeFirst