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;
}