算法过程学习

最近刚开始接触算法,把每天学到的和写出出来的代码做一个记录。

*随机输入一个数,判断是不是素数

public class isPrime {
public static void main(String[] args) {
        Scanner input =new Scanner(System.in);
        System.out.print("请输入要判断的自然数:");
         int a=input.nextInt();
        System.out.print(a+"是一个素数的判断结果为:"+isPrime(a));
}
        //判断一个数是否为素数的方法
        public static boolean isPrime(int a){
                boolean flag=true;
                   if(a <2 ){
                        flag=false;
                    }
                    for(int i=2;i*i<=a;i++){
                        if(a % i==0){
                        flag=false;
                        }
                    }
            return flag;
       }

}


怎么用牛顿迭代法求平方根

假设a。欲求a的平方根,首先猜测一个值X1=a/2,然后根据迭代公式X(n+1)=(Xn+a/Xn)/2,算出X2,再将X2代公式的右边算出X3等等,直到连续两次算出的Xn和X(n+1)的差的绝对值小于某个值,即认为找到了精确的平方根。

*编写计算平方根的算法(sqrt),(牛顿迭代法)
public class sqrt {
        public static void main(String[] args) {
        Scanner input =new Scanner(System.in);
        System.out.print("请输入要开平方根的数:");
        double a=input.nextDouble();
        System.out.print(a+"开平方后等于:"+sqrt(a));
}
    public static double sqrt(double c){
            if (c<0){
                return Double.NaN;
            }
            double err=1e-15;
            double t=c;
            while(Math.abs(t -c/t) > err *t){
                    t=(c/t +t)/2.0;
             }
            return t;
      }
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值