java-判断一个自然数是否是某个数的平方。当然不能使用开方运算

编程技术  /  houtizong 发布于 3年前   56
public class SquareRoot {/** * 题目:判断一个自然数是否是某个数的平方。当然不能使用开方运算 * 方法1.squareRoot0二分查找 * 方法2.squareRoot1 * 考虑等差数列 1 3 5 7 9...发现 * 1^2=1 * 2^2=1+3 * 3^2=1+3+5 * ... * 因此,N-1-3-5...若刚好可减至0,则N是某正整数的平方 */public static void main(String[] args) {for(int i=0;i<100;i++){squareRootOf(i);}}public static void squareRootOf(int n){if(n<1){return;}int x0=squareRoot0(n);if(x0!=-1){System.out.printf("%d*%d=%d%n", x0,x0,n);}int x1=squareRoot1(n);if(x1!=-1){System.out.printf("%d*%d=%d%n", x1,x1,n);}}//return sqrt(n).Use binary searchpublic static int squareRoot0(int n){int low=1;int high=n;while(low<=high){int mid=(low&high)+(high^low)/2;if(mid*mid==n){//mid*mid,overflow? I don't know how to avoid this.return mid;}else if(mid*mid<n){low=mid+1;}else{high=mid-1;}}return -1;}//return sqrt(n).public static int squareRoot1(int n){int d=1;//d=1,3,5...int count=0;while(n>0){n-=d;d+=2;count++;if(n==0){return count;}}return -1;}}

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

留言需要登陆哦

技术博客集 - 网站简介:
前后端技术:
后端基于Hyperf2.1框架开发,前端使用Bootstrap可视化布局系统生成

网站主要作用:
1.编程技术分享及讨论交流,内置聊天系统;
2.测试交流框架问题,比如:Hyperf、Laravel、TP、beego;
3.本站数据是基于大数据采集等爬虫技术为基础助力分享知识,如有侵权请发邮件到站长邮箱,站长会尽快处理;
4.站长邮箱:[email protected];

      订阅博客周刊 去订阅

文章归档

文章标签

友情链接

Auther ·HouTiZong
侯体宗的博客
© 2020 zongscan.com
版权所有ICP证 : 粤ICP备20027696号
PHP交流群 也可以扫右边的二维码
侯体宗的博客