牛顿迭代法计算整数除法

本文介绍了如何运用牛顿迭代法计算整数除法,通过将除法转换为乘法形式,然后利用牛顿迭代公式不断逼近求解,详细展示了迭代过程和公式推导。

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

假定x、y的值分别为M和N,需要计算$ x \div y $的值

x=Nx = Nx=N

y=My = My=M

将除法格式变换为数据相乘

xy=x×1y=N×1M\frac{x}{y} = x\times\frac{1}{y} = N\times\frac{1}{M}yx=x×y1=N×M1

如何得到 1M\frac{1}{M}M1,如下方程为0时刻的解

f(x)=1x−M(EQ.1)f(x)=\frac{1}{x}-M \quad (EQ.1)f(x)=x1M(EQ.1)

可导情况下

f(x1)=f(x0)+f′(x0)(x1−x0)f(x_1) = f(x_0)+f'(x_0)(x_1-x_0)f(x1)=f(x0)+f(x0)(x1x0)

f(x1)=0f(x_1)=0f(x1)=0,则

0=f(x0)+f′(x0)(x1−x0)0 = f(x_0)+f'(x_0)(x_1-x_0)0=f(x0)+f(x0)(x1x0)

得到牛顿迭代公式

x1=x0−f(x0)f′(x0)(EQ.2)x_1 = x_0 - \frac{f(x_0)}{f'(x_0)} \quad (EQ.2)x1=x0f(x0)f(x0)(EQ.2)

将EQ.1代入EQ.2得到:

x1=x0−1x0−M(1x0−M)′x_1 = x_0 - \frac{\frac{1}{x_0}-M}{(\frac{1}{x_0}-M)'}x1=x0(x01M)x01M

x1=x0−1x0−M(1x0−M)′x_1 = x_0 - \frac{\frac{1}{x_0}-M}{(\frac{1}{x_0}-M)'}x1=x0(x01M)x01M

x1=x0−1x0−M−1x02x_1 = x_0 - \frac{\frac{1}{x_0}-M}{-\frac{1}{x_0^2}}x1=x0x021x01M

x1=x0+x0×(1−M×x0)x_1 = x_0 + x_0\times(1-M \times x_0)x1=x0+x0×(1M×x0)

x1=x0×(2−M×x0)x_1 = x_0\times(2-M \times x_0)x1=x0×(2M×x0)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值