利用长除法取余

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

大家好,欢迎来到IT知识分享网。

利用长除法取余//灵感来源

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

一 长除法

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

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

假设,被除数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,然后再加上下一位的被除数,知道求出整个算式的余数为止,举例:

利用长除法取余

不知道你有没有看懂呢?

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/148545.html

(0)
上一篇 2025-03-30 14:26
下一篇 2025-03-30 14:33

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信