数论——同余

HDU 1212  题目链接  点击打开链接

description:给定一个大数a, 求模b的结果。

题目分析:由于a很大,因此需要引入字符串进行处理!

算法分析:   同余定理

1. ( m + n ) % c =  (m % c + n% c) % c

2. (m* n ) % c =( (m % c ) * ( n% c))  % c

3. (m ^ n) % c = ((m % c) ^ n)  % c                   (此定理可用于快速幂运算   另作讨论)

此题需要用到定理1 。举个例子:设大数 m = 1234, 模n。

其结果为    ((((1 * 10) % n + 2 % n) % n* 10 % n + 3 % n) % n * 10 % n + 4 % n) % n

此题代码:

#include <iostream>
using namespace std;

char a[1010];

int main()
{
	int b;
	while (cin >> a>> b)
	{
		int flag = 0;
		for (int i = 0; a[i] != '\0'; i++)
			flag = ((flag * 10) % b+ (a[i] - '0') %b) % b;
		cout << flag << endl;
	}
	return 0;
}

大数求余模板

/* 大数a, 模b*/
#include <iostream>
using namespace std;

char a[1010];

int main()
{
	int b;
	while (cin >> a>> b)
	{
		int flag = 0;                //作为临时保存变量
		for (int i = 0; a[i] != '\0'; i++)
			flag = ((flag * 10) % b+ (a[i] - '0') % b) % b;
		cout << flag << endl;
	}
	return 0;
} 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值