【模板】线性求逆元(洛谷P3367)

Description

  给定\(n\),\(p\)\(1~n\)中所有整数在模\(p\)意义下的乘法逆元。

Input

  一行\(n\),\(p\)

Output

  \(n\)行,第\(i\)行表示\(i\)在模\(p\)意义下的逆元。

Solution

#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int n,p,inv[30000000];
int main()
{
	scanf("%d%d",&n,&p);
	inv[1]=1;
	for (int i=2;i<=n;i++) inv[i]=1LL*(p-p/i)*inv[p%i]%p;
	for (int i=1;i<=n;i++) printf("%d\n",inv[i]);
	return 0;
}

posted @ 2018-11-06 20:35  Starryskies  阅读(106)  评论(0编辑  收藏  举报