367有效的完全平方数(牛顿迭代法)

1、题目描述

给定一个正整数 num,编写一个函数,如果 num 是一个完全平方数,则返回 True,否则返回 False。

说明:不要使用任何内置的库函数,如  sqrt。

2、示例

输入:16
输出:True

3、题解

基本思想:牛顿迭代法,f(x)=x^2-N,求f(x)=0时,x的值。初始x=N,不断求x位置的切线与x轴的交点作为新的x,如此反复,直至x^2与N差值小于1,便得到sqrt(N)的整数部分。初始点(x0,x0^2-N),y`=2*x0,得到切线方程y-(x0^2-N)=2*x0(x-x0),当y=0时得x=(x0-N/x0)/2。

#include<iostream>
#include<vector>
#include<algorithm>
#include<set>
#include<map>
using namespace std;
class Solution {
public:
    bool isPerfectSquare(int num) {
        //基本思想:牛顿迭代法,f(x)=x^2-N,求f(x)=0时,x的值。
        //初始x=N,不断求x位置的切线与x轴的交点作为新的x,如此反复,直至x^2与N差值小于1,便得到sqrt(N)的整数部分
        //初始(x0,x0^2-N),y`=2*x0,得到切线方程y-(x0^2-N)=2*x0(x-x0),当y=0时得x=(x0-N/x0)/2
        long long root=num;
        while(root*root-num>=1)
        {
            root=(root+num/root)/2;
        }
        return root*root==num;
    }
};
int main()
{
    Solution solute;
    int num=16;
    cout<<solute.isPerfectSquare(num)<<endl;
    return 0;
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值