sqrtx

Implementint sqrt(int x).Compute and return the square root of x.

//给定数字x 求解x的开方。

class Solution {
public:
    int sqrt(int x) {
        if(x <=1)
            return x;

        int begin = 1;
        int end = x;
        int middle = 0;
        while(begin <= end){
            middle = begin+(end-begin)/2;
            if(middle ==x/middle)
                return middle;
            else{
                if(middle < x/middle){
                    begin = middle+1;
                }else{
                    end = middle-1;
                }
            }
        }
        if(end*end>x) return end-1;
           return end;
    }
};
时间: 2024-10-12 04:17:13

sqrtx的相关文章

算法与数据结构总结1 二分查找与旋转排序数组

一. 二分搜索(Binary Search)模板及其理解 1.通用模板,解决start, end, mid, <(<=), >(>=)等问题 http://www.lintcode.com/en/problem/binary-search/ class Solution { public: /** * @param nums: The integer array. * @param target: Target number to find. * @return: The firs

Sqrt(x)

https://leetcode.com/problems/sqrtx 这题实际上是要求实现牛顿法吧,但是暴力找也是可以accept 的,毕竟是以n^2 的速度逼近答案. /** * @param {number} x * @return {number} */ var mySqrt = function(x) { var i; for (i = 1; i*i <= x; ++i); return i - 1; }; console.log(mySqrt(0)); var mySqrt = fu

[LeetCode][JavaScript]Sqrt(x)

Sqrt(x) Implement int sqrt(int x). Compute and return the square root of x. https://leetcode.com/problems/sqrtx/ 对于数学早就还给老师的我,开方真是跪了. 查了一下是牛顿迭代法(什么鬼. 先随便猜一个数,我就猜了三分之一,然后套用公式. candidate = (candidate + x / candidate) / 2; 题目要求返回int型,我精度就算到了0.01. 查牛顿迭代法

【C++探索之旅】第一部分第五课:简易计算器

内容简介 1.第一部分第五课:简易计算器 2.第一部分第六课预告:控制流程,随心所至 简易计算器 上一课<[C++探索之旅]第一部分第四课:内存,变量和引用>中,我们已经学习了挺重要的内存的概念,变量的知识,对引用这个C++中常用的技术也有了初步的了解. 我们在上一课开头处用一个小小计算器的存储技术引出内存的概念.其实我们的电脑兄也是一个计算器,只不过高端大气上档次了很多,不然怎么会被称为 computer呢?英语中compute这个词,正是<计算>的意思,而加上r就构成了名词.c

[HDOJ 5212] [BestCoder Round#39] Code 【0.0】

题目链接:HDOJ - 5212 题目分析 首先的思路是,考虑每个数对最终答案的贡献. 那么我们就要求出:对于每个数,以它为 gcd 的数对有多少对. 显然,对于一个数 x ,以它为 gcd 的两个数一定都是 x 的倍数.如果 x 的倍数在数列中有 k 个,那么最多有 k^2 对数的 gcd 是 x . 同样显然的是,对于两个数,如果他们都是 x 的倍数,那么他们的 gcd 一定也是 x 的倍数. 所以,我们求出 x 的倍数在数列中有 k 个,然后就有 k^2 对数满足两个数都是 x 的倍数,这

[BZOJ 2440] [中山市选2011] 完全平方数 【二分 + 莫比乌斯函数】

题目链接:BZOJ - 2440 题目分析 首先,通过打表之类的方法可以知道,答案不会超过 2 * k . 那么我们使用二分,对于一个二分的值 x ,求出 [1, x] 之间的可以送出的数有多少个. 怎么来求呢?我们使用容斥原理. 先求出不能送的数(即含有平方因子的数)有多少个,然后用总数减去就可以了. 那么,就是 含有一个质数平方因子的数(2^2的倍数 + 3^2的倍数 + 5^2的倍数....) - 含有两个质数平方因子的数((2 * 3)^2的倍数 + (2 * 5)^2的倍数 + ...

[leetcode]Sqrt(x) @ Python

原题地址:https://oj.leetcode.com/problems/sqrtx/ 题意: Implement int sqrt(int x). Compute and return the square root of x. 解题思路:实现开平方函数.这里要注意的一点是返回的时一个整数.通过这一点我们可以看出,很有可能是使用二分查找来解决问题的.这里要注意折半查找起点和终点的设置.起点i=1:终点j=x/2+1:因为在(x/2+1)^2 > x,所以我们将折半查找的终点设为x/2+1.

LeetCode题目总结分类

注:此分类仅供大概参考,没有精雕细琢.有不同意见欢迎评论~ 利用堆栈:http://oj.leetcode.com/problems/evaluate-reverse-polish-notation/http://oj.leetcode.com/problems/longest-valid-parentheses/ (也可以用一维数组,贪心)http://oj.leetcode.com/problems/valid-parentheses/http://oj.leetcode.com/probl

转载 ACM训练计划

leetcode代码 利用堆栈:http://oj.leetcode.com/problems/evaluate-reverse-polish-notation/http://oj.leetcode.com/problems/longest-valid-parentheses/ (也可以用一维数组,贪心)http://oj.leetcode.com/problems/valid-parentheses/http://oj.leetcode.com/problems/largest-rectang