题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4992

题意:给出n,输出n的所有原根。

思路:求出n的一个原根x,那么对于所以的i,i<phi(n)且(i,phi(n))=1,x^i%n都是n的原根。

int Euler(int n)
{
    int i,ans=n;
    for(i=2;i*i<=n;i++) if(n%i==0)
    {
        ans=ans/i*(i-1);
        while(n%i==0) n/=i;
    }
    if(n>1) ans=ans/n*(n-1);
    return ans;
}

int prime[N],tag[N],cnt;

void init()
{
	int i,j;
	for(i=2;i<N;i++) if(!tag[i])
	{
		prime[cnt++]=i;
		for(j=i+i;j<N;j+=i) tag[j]=1;
	}
	tag[1]=1;
}

int get(int x)
{
	if(x%2==0) return 0;
	int i;
	for(i=0;i<cnt&&prime[i]*prime[i]<=x;i++) if(x%prime[i]==0)
	{
		while(x%prime[i]==0) x/=prime[i];
		if(x!=1) return 0;
		return prime[i];
	}
	return x;
}

int n;

int myPow(i64 x,i64 y)
{
	i64 ans=1;
	while(y)
	{
		if(y&1) ans=ans*x%n;
		x=x*x%n;
		y>>=1;
	}
	return (int)ans;
}

int ee;

vector<int> V;

int ok(int t)
{
	if(myPow(t,ee)!=1) return 0;
	int i;
	FOR0(i,SZ(V)) if(myPow(t,V[i])==1) return 0;
	return 1;
}

int Gcd(int x,int y)
{
	if(y==0) return x;
	return Gcd(y,x%y);
}

int main()
{

	init();
	while(scanf("%d",&n)!=-1)
	{
		if(n==2)
		{
			puts("1");
			continue;
		}
		if(n==4)
		{
			puts("3");
			continue;
		}

		int t=n%2==0?get(n/2):get(n);
		if(!t)
		{
			puts("-1");
			continue;
		}

		ee=Euler(n);
		V.clear();
		int i;
		for(i=2;i*i<=ee;i++) if(ee%i==0)
		{
			V.pb(i);
			if(i*i!=ee) V.pb(ee/i);
		}
		for(i=2;i<n;i++) if(ok(i)) break;
		int Min=i;
		vector<int> ans;
		for(i=1;i<ee;i++)
		{
			if(Gcd(i,ee)!=1) continue;
			ans.pb(myPow(Min,i));
		}
		sort(all(ans));
		for(i=0;i<SZ(ans);i++)
		{
			if(i) putchar(' ');
			printf("%d",ans[i]);
		}
		puts("");
	}
}

hdu4992 Primitive Roots(所有原根)的更多相关文章

  1. 【HDU 4992】 Primitive Roots (原根)

    Primitive Roots   Description We say that integer x, 0 < x < n, is a primitive root modulo n i ...

  2. POJ 1284 Primitive Roots 数论原根。

    Primitive Roots Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 2479   Accepted: 1385 D ...

  3. poj 1284 Primitive Roots (原根)

    Primitive Roots http://poj.org/problem?id=1284 Time Limit: 1000MS   Memory Limit: 10000K       Descr ...

  4. POJ_1284 Primitive Roots 【原根性质+欧拉函数运用】

    一.题目 We say that integer x, 0 < x < p, is a primitive root modulo odd prime p if and only if t ...

  5. POJ 1284:Primitive Roots 求原根的数量

    Primitive Roots Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 3381   Accepted: 1980 D ...

  6. [POJ1284]Primitive Roots(原根性质的应用)

    题目:http://poj.org/problem?id=1284 题意:就是求一个奇素数有多少个原根 分析: 使得方程a^x=1(mod m)成立的最小正整数x是φ(m),则称a是m的一个原根 然后 ...

  7. poj 1284 Primitive Roots(原根+欧拉函数)

    http://poj.org/problem?id=1284 fr=aladdin">原根 题意:对于奇素数p,假设存在一个x(1<x<p),(x^i)%p两两不同(0&l ...

  8. POJ 1284 Primitive Roots 原根

    题目来源:POJ 1284 Primitive Roots 题意:求奇素数的原根数 思路:一个数n是奇素数才有原根 原根数是n-1的欧拉函数 #include <cstdio> const ...

  9. POJ 1284:Primitive Roots(素数原根的个数)

    Primitive Roots Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 5709 Accepted: 3261 Descr ...

随机推荐

  1. JDBCTest

    package com.atguigu.spring.jdbc; import java.sql.SQLException; import java.util.ArrayList; import ja ...

  2. AP模块的发票过账后关联对应的凭证编号。

    --AP发票 SELECT GJH.NAME,GJH.LEDGER_ID,GJH.JE_CATEGORY, GJH.JE_SOURCE,XDL.SOURCE_DISTRIBUTION_TYPE, XT ...

  3. 夺命雷公狗jquery---3普通选择器

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  4. 一个fork()系统调用的问题

    转载:http://coolshell.cn/articles/7965.html 题目:请问下面的程序一共输出多少个“-”? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...

  5. java concurrency in practice读书笔记---ThreadLocal原理

    ThreadLocal这个类很强大,用处十分广泛,可以解决多线程之间共享变量问题,那么ThreadLocal的原理是什么样呢?源代码最能说明问题! public class ThreadLocal&l ...

  6. 在CentOS 6 32/64 上安装 PPTP 方式 VPN 服务

    网上有很多步骤, 讲了很多步骤,废话, 其实不如直接看代码, 而且也能直接运行,快速安装: rm -f /etc/pptpd.conf rm -f /etc/ppp arch=`uname -m` # ...

  7. PHP memcached 扩展的安装

    PHP memcached 扩展的安装 1.下载相关的源码包(软件版本自己选择) memcached-1.4.15 , http://memcached.org/ //Memcached服务端. me ...

  8. C#:将子Form加入父Form中

    实现的功能:已建立了多个子Form界面,在父Form界面左面,点击不同标题的链接文本,父Form界面右面显示不同的子界面内容. 具体如下: 1.加入split拆分器控件 2.在splitControl ...

  9. javaScript判断鼠标滚轮的上下滚动

    分享一个js实现判断鼠标滚轮的上下滚动: <script type="text/javascript"> var scrollFunc = function (e) { ...

  10. Android invalidate() 和 postInvalidate()的区别

    Android提供了Invalidate方法实现界面刷新,但是Invalidate不能直接在线程中调用,因为他是违背了单线程模型:Android UI操作并不是线程安全的,并且这些操作必须在UI线程中 ...