/**
* 双射类
* 在给定自然数空间一对一完全映射,可逆运算,不可猜解
* @author liuxu
*
*/
class Bijective
{
static private $defaultPrime = '85310501873';//请使用个位为"3"、"7"、"9"的质数
static public function getRandPrime()
{
return self::getMinPrime(rand(100000,900000)*100000+rand(100000,900000));
}
static public function getMinPrime($min)
{
$number = $min;
while(true)
{
if(self::isPrime($number)) break;
$number++;
}
return $number;
}
static public function isPrime($number)
{
$sqrt = intval(bcsqrt($number,0));
for($i=2;$i<=$sqrt;$i++)
{
if(bcmod($number,$i)==='0')
{
return false;
}
}
return true;
}
static public function mod($number,$len=10)
{
return bcmod(bcmul($number,self::$defaultPrime,0),bcpow(10,$len,0));
}
static public function loop($number,$len=8)
{
$min = $prev = $number;
for($i=1;;$i++)
{
$next = self::mod($prev,$len);
if($next==$number) break;
$min = min($min,$next);
$prev = $next;
}
$offset = ( $min % $i ) + 1;
for($j=0;$j<$offset;$j++)
{
$number = self::mod($number,$len);
}
return $number;
}
static public function insanity($number,$len=10)
{
$number = self::mod($number,$len);
$number = str_pad($number,$len,'0',STR_PAD_LEFT);
$numberList = str_split($number,6);
foreach($numberList as $key=>$value)
{
$numberList[$key] = str_pad(self::loop($value,strlen($value)),strlen($value),'0',STR_PAD_LEFT);
}
$number = implode('',$numberList);
return $number;
}
} 0
0
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
不受国内限制的浏览器大全
想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!
41
2025.12.31
html5怎么播放视频
想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。
9
2025.12.31
html5怎么使用
想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!
2
2025.12.31
热门下载
相关下载
精品课程
相关推荐
/
热门推荐
/
最新课程






