bzoj1406
这道题很有意思
我们解过线性同余方程,也解过同余方程
这个则是求x^2≡1 (mod p)
可以将问题转化为(x-1)(x+1)≡0 (mod p)
然后我们穷举一下p的约数i,
看i|x-1,p/i|x+1 或者i|x+1, p/i|x-1是否可行解
然后排序去重即可
var ans:array[..] of longint;
a,n,i,b,t:longint;
j:int64; procedure sort(l,r:longint);
var i,j,x,y:longint;
begin
i:=l;
j:=r;
x:=ans[(l+r) shr ];
repeat
while ans[i]<x do inc(i);
while x<ans[j] do dec(j);
if not(i>j) then
begin
y:=ans[i];
ans[i]:=ans[j];
ans[j]:=y;
inc(i);
j:=j-;
end;
until i>j;
if l<j then sort(l,j);
if i<r then sort(i,r);
end; begin
readln(n);
for i:= to trunc(sqrt(n)) do
if n mod i= then
begin
b:=n div i;
j:=;
while j<=n do
begin
if (j+) mod i= then
begin
inc(t);
ans[t]:=j;
end;
j:=j+b; //保证x-是b的倍数
end;
j:=b-;
while j<=n do
begin
if (j-) mod i= then
begin
inc(t);
ans[t]:=j;
end;
j:=j+b;
end;
end;
sort(,t);
for i:= to t do
if ans[i]<>ans[i-] then writeln(ans[i]);
end.
bzoj1406的更多相关文章
- BZOJ1406 [AHOI2007]密码箱  数论
		
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1406 题意概括 求所有数x,满足 x<n 且 x2≡1 (mod n). n<=2 ...
 - [BZOJ1406][AHOI2007]密码箱(数论)
		
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1406 分析: (x+1)(x-1)是n的倍数 于是可以把n分解成n=ab,则a为(x+ ...
 - 【BZOJ-1406】密码箱    约数 + 乱搞 + set?
		
1406: [AHOI2007]密码箱 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1143 Solved: 677[Submit][Status][ ...
 - bzoj1406: [AHOI2007]密码箱
		
数学. x^2 % n = 1 则 (x+1)(x-1) = kn. 设 x+1 = k1*n1, x-1=k2*n2. 则 k1*k2=k , n1*n2=n. 算出每个大于sqrt(n)的约数,然 ...
 - [BZOJ1406]密码箱
		
Problem 给你1个数n,求出0 ≤ x < n,并且x ^ 2 % n = 1 Solution x ^ 2 - 1 = kn,(x - 1) * (x + 1) = kn 所以枚举n的约 ...
 - 2018.12.17 bzoj1406 : [AHOI2007]密码箱(简单数论)
		
传送门 简单数论暴力题. 题目简述:要求求出所有满足x2≡1mod  nx^2\equiv1 \mod nx2≡1modn且0≤x<n0\ ...
 - 【bzoj1406】 AHOI2007密码箱 数论
		
在一次偶然的情况下,小可可得到了一个密码箱,听说里面藏着一份古代流传下来的藏宝图,只要能破解密码就能打开箱子,而箱子背面刻着的古代图标,就是对密码的提示.经过艰苦的破译,小可可发现,这些图标表示一个数 ...
 - 【bzoj1406】[AHOI2007]密码箱
		
x2 ≡ 1 mod n => x2 = k * n + 1 => n | (x + 1) * (x - 1) 令n = a * b,则 (a | x + 1 且 b | x - 1) 或 ...
 - [转载]hzwer的bzoj题单
		
counter: 664BZOJ1601 BZOJ1003 BZOJ1002 BZOJ1192 BZOJ1303 BZOJ1270 BZOJ3039 BZOJ1191 BZOJ1059 BZOJ120 ...
 
随机推荐
- ORA-12011+ORA-06512–job执行失败问题
			
oracle库中的一个job,正常运行了一年多,因某种原因导致无法运行,系统尝试多次均失败之后下次执行时间就变成了 4000/1/1. 现导致job失败的问题已经解决,从新运行job时报 12011和 ...
 - V$SESSION_LONGOPS
			
对大部分DBA来说,V$SESSION_LONGOPS视图都不会陌生,以前在面试的时候,也有一些企业会问到如何查询数据库中运行时间比较长的SQL,就可以通过这个视图来查看.V$SESSION_LONG ...
 - skip跳跃表的实现
			
skiplist介绍 跳表(skip List)是一种随机化的数据结构,基于并联的链表,实现简单,插入.删除.查找的复杂度均为O(logN).跳表的具体定义, 跳表是由William Pugh发明的, ...
 - Android版多线程下载器核心代码分享
			
首先给大家分享多线程下载核心类: package com.example.urltest; import java.io.IOException; import java.io.InputStream ...
 - MinGW 仿 linux 开发环境
			
MinGW 默认安装 MSYS.通常打开的 MinGW Shell 其实 MSYS,MinGW 作为一个组件存在. MSYS -- Minimal SYStem,是一个 Bourne Shell 解释 ...
 - 设计模式之 Factory Method 工厂方法
			
看到的比较有意思的一篇描述工厂方法的文章. http://www.codeproject.com/Articles/492900/From-No-Factory-to-Factory-Method 总 ...
 - JQuery AJAX介绍
			
new ActiveXObject("Microsoft.XMLHTTP")是IE中创建XMLHttpRequest对象的方法.非IE浏览器中创建方法是new XmlHttpReq ...
 - nginx 502
			
查过网上的资源,基本都是认为是php线程打开文件句柄受限导致的错误.具体的解决的办法如下: 1.提升服务器的文件句柄打开打开 /etc/security/limits.conf : (增加) * ...
 - gcc 生成动态库时-fpic选项是什么意思。
			
-f后面跟一些编译选项,PIC是其中一种,表示生成位置无关代码(Position Independent Code)
 - Google Web Designer 测试
			
这东东完全就是一个flash啊,简单测试,感觉就是个做HTML5动画的..不过暂时是beta版的, 官方安装版的半天打不开,这边有个绿色版的,需要的童鞋可以这里下载:百度网盘