已知一算法,求其逆向算法。分不够的话要多少给多少!!!

menlion 2002-11-13 08:44:10
Java 的 BigInteger 类中有这样一个method:

BigInteger modPow(BigInteger exponent,BigInteger m)

求的是this的exponent次幂对m取模的结果。

有代码如下:
byte[] b0 = ...;
BigInteger b1 = ...;
BigInteger b2 = ...;
BigInteger result = (new BigInteger(b0)).modPow(b1, b2);


现在的路径是: b0 ==> result;
请找出 result ==> b0 的路径?

已知:上面这段伪码中 b0 、 b1 和 b2 都是100位以上的十进制数
问: 由 result 到 b0 的最快捷的算法是什么?

注:请不要提查表法,因为把这个表建立起来的工作量也是非常之庞大的。
...全文
71 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
menlion 2002-12-13
  • 打赏
  • 举报
回复
请问,密钥长度是如何计算的?256bit是指密钥大小小于2^256吗?
strafer 2002-12-11
  • 打赏
  • 举报
回复
如果它用的密钥长度超过256bit,就不一定能在短时间内解决了。
menlion 2002-12-11
  • 打赏
  • 举报
回复
谢谢strafer(努力中...)、mathe和bjay(ben)啦!

其实,我正在用ProductivityPro!这个JBuilder的插件,可它的注册费居然是一百多美刀,我就想把它Crack了,结果就找到它的加密算法是这个了,呵呵^_^
crystal_heart 2002-12-10
  • 打赏
  • 举报
回复
Java 的 BigInteger 类中有这样一个method:

BigInteger modPow(BigInteger exponent,BigInteger m)

求的是this的exponent次幂对m取模的结果。

有代码如下:
byte[] b0 = ...;
BigInteger b1 = ...;
BigInteger b2 = ...;
BigInteger result = (new BigInteger(b0)).modPow(b1, b2);


现在的路径是: b0 ==> result;
请找出 result ==> b0 的路径?

已知:上面这段伪码中 b0 、 b1 和 b2 都是100位以上的十进制数
问: 由 result 到 b0 的最快捷的算法是什么?

注:请不要提查表法,因为把这个表建立起来的工作量也是非常之庞大的。
strafer 2002-11-15
  • 打赏
  • 举报
回复
同意bjay(ben)的说法。

这就是RSA,逆算也是这个过程,不过所不同的是EXPONENT值。

细节就找个rfc看看吧。

还有,mathe,这个不应该是离散对数问题吧,应该是大数分解的问题。
mathe 2002-11-15
  • 打赏
  • 举报
回复
这是一个NP问题,称为离散对数问题,你即使想用差表法也用不了:)
menlion 2002-11-15
  • 打赏
  • 举报
回复
:(
bjay 2002-11-14
  • 打赏
  • 举报
回复
这是个数学难题,解决了,RSA也就不安全了。:)
以太坊是一个平台,它上面提供各种模块让用户来搭建应用,如果将搭建应用比作造房子,那么以太坊就提供了墙面、屋顶、地板等模块,用户只需像搭积木一样把房子搭起来,因此在以太坊上建立应用的成本和速度都大大改善。具体来说,以太坊通过一套图灵完备的脚本语言(Ethereum Virtual Machinecode,简称EVM语言)来建立应用,它类似于汇编语言。我们知道,直接用汇编语言编程是非常痛苦的,但以太坊里的编程并不需要直接使用EVM语言,而是类似C语言、Python、Lisp等高级语言,再通过编译器转成EVM语言。上面所说的平台之上的应用,其实就是合约,这是以太坊的核心。合约是一个活在以太坊系统里的自动代理人,他有一个自己的以太币地址,当用户向合约的地址里发送一笔交易后,该合约就被激活,然后根据交易中的额外信息,合约会运行自身的代码,最后返回一个结果,这个结果可能是从合约的地址发出另外一笔交易。需要指出的是,以太坊中的交易,不单只是发送以太币而已,它还可以嵌入相当多的额外信息。如果一笔交易是发送给合约的,那么这些信息就非常重要,因为合约将根据这些信息来完成自身的业务逻辑。合约所能提供的业务,几乎是无穷无尽的,它的边界就是你的想象力,因为图灵完备的语言提供了完整的自由度,让用户搭建各种应用。白皮书举了几个例子,如储蓄账户、用户自定义的子货币等。 2013年年末,以太坊创始人Vitalik Buterin发布了以太坊初版白皮书,启动了项目。2014年7月24日起,以太坊进行了为期42天的以太币预售。2016年初,以太坊的技术得到市场认可,价格开始暴涨,吸引了大量开发者以外的人进入以太坊的世界。中国三大比特币交易所之二的火币网及OKCoin币行都于2017年5月31日正式上线以太坊。 [1] 自从进入2016年以来,那些密切关注数字货币产业的人都急切地观察着第二代加密货币平台以太坊的发展动向。作为一种比较新的利用比特币技术的开发项目,以太坊致力于实施全球去中心化且无所有权的的数字技术计算机来执行点对点合约。简单来说就是,以太坊是一个你无法关闭的世界计算机。加密架构与图灵完整性的创新型结合可以促进大量的新产业的出现。反过来,传统行业的创新压力越来越大,甚至面临淘汰的风险。比特币网络事实上是一套布式的数据库,而以太坊则更进一步,她可以看作是一台布式的计算机:区块链是计算机的ROM,合约是程序,而以太坊的矿工们则负责计算,担任CPU的角色。这台计算机不是、也不可能是免费使用的,不然任何人都可以往里面存储各种垃圾信息和执行各种鸡毛蒜皮的计算,使用它至少需要支付计算费和存储费,当然还有其它一些费用。最为知名的是2017年初以摩根大通、芝加哥交易所集团、纽约梅隆银行、汤森路透、微软、英特尔、埃森哲等20多家全球top金融机构和科技公司成立的企业以太坊联盟。而以太坊催生的加密货币以太币近期又成了继比特币之后受追捧的资产。  智能合约的潜在应用很多。彭博社商业周刊称它是“所有人共享但无法篡改的软件”。更高级的软件有可能用以太坊创建网络商店。区块链程序以太坊可以用来创建去中心化的程序、自治组织和智能合约,据纽约时报的报导,在2016年5月已经有数十个可用的程序。预期的应用目标涵盖金融、物联网、农田到餐桌(farm-to-table)、智能电网、体育,菠菜等。去中心化自治组织有潜力让许多原本无法运行或成本过高的营运模型成为可能。较知名的应用有:去中心化创业投资:The DAO用以太币资金创立,目标是为商企业和非营利机构创建新的去中心化营业模式、The Rudimental让独立艺术家在区块链上进行群众募资。社会经济平台:Backfeed。去中心化预测市场:Augur。物联网:Ethcore(一间以太坊公司)研发的客户端、Chronicled(一间区块链公司)发表了以太坊区块链的实物资产验证平台;芯片公司、物理IP创建者和生产者可以用植入的蓝牙或近场通信进行验证。Slock.It开发的智能锁可以在付费后自动打开,让用户在付费后可以帮电动车充电、或是打开租屋的房门。虚拟宝物交易平台:FreeMyVunk。版权授权:Ujo Music平台让创作人用智能合约发布音乐,消费者可以直接付费给创作人。伊莫珍·希普用此平台发布了一首单曲。智能电网:TransActive Grid让用户可以和邻居买卖能源。去中心化期权市场:Etheropt。钉住汇率的代币:DigixDAO提供与黄金挂钩的代币,在2016年四月正式营运。Decentralized Capital提供和各种货币挂钩的代币。移动支付:Everex让外劳汇款回家乡。客户端软件以太坊的两个主要的客户端软件是Geth和Parity。企业软件企业软件公司也正测试用以太坊作为各种用途。已知有兴趣的公司包括微软、IBM、摩根大通。德勤和ConsenSys在2016年

33,008

社区成员

发帖
与我相关
我的任务
社区描述
数据结构与算法相关内容讨论专区
社区管理员
  • 数据结构与算法社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧