一种用自然对数开n次方根的方法

本文介绍了一种使用自然对数进行n次方根运算的方法,通过将开方问题转化为指数计算问题,并采用递归方式求解e的幂,解决了传统方法难以处理的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一种用自然对数开n次方根的方法

以前是用newton展开做过这方面的尝试:

现在换种方法

比如7^(1/3)=a

Go

log 7^(1/3)=log a

Go

1/3* (log 7) =log a

GO

a=e^{ 1/3* (log 7)  }

 

其中log是系统函数,而e^x的值可以用展开法计算,不过我们在这里利用上次的成果间接计算e^x的值:

 

(defun pow (num count)

(if (or (> count 1) (eq  count  1) )

      (* num 

         (pow num 

              (- count 1) ) )

      1))

 

(defun slayer ( count)

(if (or (> count 1) (eq  count  1) )

      (* count 

         (slayer  

              (- count 1) ) )

      1))

 

(setq material (*  (log 7)

                   (/  1  

                       3)))

(defun  expr (n)

(if (eq  n 1)

       1.0

    (+ 

       (*  n 

           (expr  (-  n  1) ))

       (*  n

           (pow   material

                  (1- n))))))

 

 

(defun  test (n)

(if (> n 0)

  (progn 

       (print (/  (expr n) (slayer n)))

       (print  'compare)

       (print  (pow  (/  (expr n)  (slayer n)) 3))  

       (test (- n 1)))

  (print 'over)))

 

(test  10) 

用这种方法解决了不能开除了sqrt外的高次方根的问题。并且采用了间接的方法,避免直接求e^(小数)的问题,因为在我们目前的pow函数中,不能处理幂为小数的情况。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值