利用长除法取余

https://blog.csdn.net/2301_79890145/article/details/134976546?spm=1001.2014.3001.5502//灵感来源

根据这道题目,一开始真的很难理解长除法取余的思维,不过当我将小学时就学过的计算被除数和除数的计算公式后,有感而发写下了这篇文章

一 长除法

概念:长除法是一种用于计算除法的手动算法,它逐位地将被除数除以除数得到商和余数

很抽象对不对,下面举个例子来说明“逐位地将被除数除以除数得到商和余数”这句话的意思

假设,被除数47598,除数4

可见,我们每算一次都是每一位的被除数除数进行一次比较,然后获得一个余数,图片中用方框圈起来的就是获得的余数,用波浪线画出来的就是作为新的被除数参与到下一轮除法运算的被除数,如果还没懂,可以自己在稿纸上运算一下,体验一下这个运算过程。

二.长除法取余(大整数无法用普通的取余)

给定除数和被除数,求余数

Input

多组测试数据,每组测试数据包含两个整数n,k(1<=n<=10^2000,1<=k<=1000)

Output

对于每组测试数据,输出n%k

核心代码,利用长除法取余

#define MAXN 2005
char n[MAXN];
int len = strlen(n);
int r = 0; // 余数
for (int i = 0; i < len; i++) {
r = r * 10 + (n[i] - '0');
r %= k;

}

printf("%d",r);

这段代码就是利用长除法取余

for (int i = 0; i < len; i++) {
r = r * 10 + (n[i] - '0');
r %= k;

}

//即按照高位取出每一位被除数,然后去除除数,得到一个余数,不论能否整除,都将除出来的余数*10,然后再加上下一位的被除数,知道求出整个算式的余数为止,举例:

不知道你有没有看懂呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值