码迷,mamicode.com
首页 > 其他好文 > 详细

数论——同余

时间:2015-08-01 10:05:20      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:算法

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


版权声明:本文为博主原创文章,未经博主允许不得转载。

数论——同余

标签:算法

原文地址:http://blog.csdn.net/xiaotan1314/article/details/47183249

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!