首 页  资讯中心 下载中心 资讯教程 最新下载 发布软件 发布文章 网通站 电信站繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:曾子源码软件下载站 -> 网络编程 -> asp.net -> 文章内容 退出登录 用户管理
热门文章
· 常用C,VC,C++书籍下..
· 新概念英语视频教程..
· 常用 JAVA JAVA2 J..
· 《梦幻麻将馆9雀圣争..
· 新东方英语视频教程..
· 常用VB,Visual Basi..
· [组图] After Effect..
· WINDOWS 所有系统文..
· [组图] 让机器运行多..
· 全美经典学习指导系..
相关文章
· [组图] ASP.NET 2.0中..
· ASP.NET2.0 数据绑定..
· .NET Framework 3.0..
· ASP.NET数据库编程之..
· ASP.NET2.0服务器控..
· ASP.NET2.0服务器控..
· ASP.NET2.0服务器控..
· 实现asp.net只对个别..
· .NET中如何在调用CO..
· 在ASP.NET应用中插入..
.net中大数处理的一些算法思想
作者: Asame BLOG     来源:不详  发布时间:2006-6-19 18:28:49  发布人:admin

减小字体 增大字体

     在 .NET 开发中,有时会因为处理一些边缘学科的知识内容,如统计,金融,天文等计算,是加密解密算法
  都会涉及到大数的运算,就是.net中最大数值类型储存了都会溢出的数,我的一个想法是计算时用数值类型,储
  存(暂时)和输出时是字符串 那么储存时就需要BOX[n] n个数组来暂时储存一个计算中的小步骤结果,
  '如一下例子
  ====================算法理解图=======================
  '97*97*97*97*97 = 8587340257 box(1) = 587340257 box(2)=8
   '97*97*97*97*97*97 = 832972004929 box(1) = 972004929 box(2)=832
  '97*97*97*97*97*97*97 = 80798284478113 box(1) = 284478113 box(2)=80798
   '97*97*97*97*97*97*97*97 = 7837433594376961 box(1) = 594376961 box(2)=7837433
  '97^ 9 = 760231058654565217 box(1) = 654565217 box(2)=760231058
   '97^ 10 = 73742412689492826049 box(1) = 492826049 box(2)=742412689 box(3)=73
   …… …… …… ……
  注意box 下表越大对应的数越高位在,在运用上面的算法时要记住
  ①先定义一个BOX的标志为几位,如上面是9位(根据需要和实际情况),
  ②由于计算习惯,很多人会从底位算起时{box(0 -> n)} 要先算box(n+1)位的数,在把box(n) 产生的进位数(如第一条计算box(1)向box(2)=0产生进位数8 box(2)+进位数 = 8 )进行处理,如以上时加法处理
  ③ 最好从高位算起,你将省去很多麻烦,box个数未知,没关系,用动态数组,满了时(最高下标box产生的进位数)再添一个
  还有取模运算时,如果模数不大,也可以采用以上思想分段求模,再链接box得暂时结果,重新分配box(一定要从高位起重新截断)如被模数 123456789123456789 设八位一个box box(1)=89 box(2)=91234567 box(3)=12345678各box分别取模再联合(传统是123456789123456789 ÷ 333=370741108478849 模是72) 那么重新分配的盒子应该是box(1) =478849 box(2) =370741180 而不能是box(1) =370741180 box(2) = 478849 为什么? ∵从高位开始取模,box(n) 在被取模一次后如果不变,再次取模结果没变是box(n) = box(n) 程序将进入死循环
   另外一种涉及大数运算的情况式是对A的n 次方后取模 (A ^n mod V ) 如果mod数不大可以(是n个A后结束)((A mod V)* A mod V) * A mod V …… 此算法不一定要用递归实现,简单的循环即可,最多两层嵌套循环
   最后忠告 :对一个大数进行加减乘除时千万别轻易的进行对被(加/减/乘/除)数因式分解,这种算法效率会很底
   (文章编写匆忙,可能存在错字,敬请原谅)
  
  出处:same BLOG  做人要厚道,请注明转自酷网动力(www.ASPCOOL.COM)。
[] [返回上一页] [打 印] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [发表评论...]
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 网站信息排名查询
Copyright © 2004-2006 Zasp.Net. All Rights Reserved .