我在Delphi中编写一个简单的BigInteger类型.此类型由无符号32位整数数组(我称之为四肢),计数(或大小)和符号位组成.数组中的值被解释为绝对值,因此这是符号幅度表示.这有几个优点,但有一个缺点.

像和和,或者xor这样的按位运算有两个补码语义.如果两个BigIntegers都有正值,则没有问题,但负BigIntegers的大小必须通过否定转换为二进制补码.这可能是一个性能问题,因为如果我们这样做,比方说

C := -A and -B;

然后我必须在执行和操作之前否定A和B的大小.由于结果也应该是否定的,我必须否定结果,以便再次获得正数.对于大型BigIntegers,否定最多三个值可能会产生相当大的性能成本.

请注意,我知道如何做到这一点并且结果是正确的,但我想避免由大数组的必要否定引起的缓慢.

例如,我知道一些快捷方式

C := not A;

可以通过计算来实现

C := -1 - A;

这就是我做的,结果很好.这不像加法或减法那样有效,因为它避免了操作之前(和之后)的否定.

我的问题是:是否有类似的法律我可以用来避免否定“负面”BigIntegers的数量?我的意思是像计算不使用减法?

我的意思是简单或不那么简单的法律

not A and not B = not (A or B) // = is Pascal for ==
not A or not B = not (A and B)

但后来为-A和/或-B等我知道

(-A and -B) <> -(A or B) // <> is Pascal for !=

不是真的,但也许有类似的东西?

我根本找不到任何与负值和按位运算相关的定律,如果它们存在的话.因此我的问题.

解决方法

上次我检查否定工作是这样的:
-A = not(A) + 1; or
-A = not(A - 1);
that means that
-A and -B = not(A - 1) and not(B - 1)

如果我们在前面添加另一个NOT而不是我们可以替换而不是
用或

not(-A and -B) = not(not(A - 1) and not(B - 1)) =
(A - 1) or (B - 1)

我们仍然需要做一个昂贵的不是最后,但因为不是如此接近 – 我们可以欺骗和替换昂贵的不便宜 – 如此:

-(-A and -B) = (A-1) or (B-1) + 1;

最后结果将是:

(-A and -B) = -((A-1) or (B-1) + 1);

这应该比翻转所有位快得多.

实施起来非常便宜,因为:

>否定是一个简单的位翻转你的符号字节.
在过度使用的情况下,> 1 / -1将很快耗尽进位/借位(仅有1/2 ^ 32个案例将进/下一个分支).

同样适用于;不是或非常接近和.

delphi – 对符号幅度大整数的按位运算的更多相关文章

  1. Swift与Objective-C:重新认识苹果的编程语言(1)

    Objective-C那极为有限的使用面也带来负面影响,即迫使该语言不得不面向利基市场。iPhoneSDK的迅速走红让一切有了转机,由于它只允许开发者选择Objective-C,这款面向对象的语言也开始席卷世界各地。Objective-C与苹果一直拥有难以置信的默契与出人意料的和谐。这是由于Objective-C与Cocoa框架之间存在着紧密的联系,Objective-C所使用的一系列设计模式能够显著提高该框架的执行效率。

  2. [翻译]Swift编程语言——高级操作符

    高级操作符在前面的基本操作符之外,为了做更复杂的值操作,Swift还提供了若干高级操作符。不同于C中的算术操作符,Swfit中的算术操作符不会默认溢出。Swift使得为这些自定义的类型量身打造标准操作符的实现变得很轻松。预定义操作符没有任何限制,Swift提供了定制中缀、前缀、后缀和指派操作符的自由。Swfit提供所有的C支持的按位操作符,下文有具体描述。CSS颜色值#CC6699依据Swift的十六进制表示法被写作0xCC6699。)有符号整型用它们的第一个bit来表示正负。

  3. The Swift Programming Language学习笔记二十六——高级运算符

    自定义结构体、类和枚举时,如果也为它们提供标准Swift运算符的实现,将会非常有用。在Swift中可以自由地定义中缀、前缀、后缀和赋值运算符,以及相应的优先级与结合性。Swift支持C语言中的全部位运算符。可以使用Swift提供的三个溢出运算符来让系统支持整数溢出运算。相对C语言和Objective-C来说,Swift的运算符优先级和结合性规则更加简洁和可预测。自定义运算符除了实现标准运算符,在Swift中还可以声明和实现自定义运算符。

  4. swift2.2 - 高级运算符

    高级运算符文档地址作为基本运算符的补充,Swift提供了几个高级运算符执行对数传值进行更加复杂的操作。与C的算术运算符不同,Swift中算术运算符默认是不会溢出的。当你定义了你自己的结构体,类以及枚举的时候,那么为这些自定义类型也提供Swift标准的运算符将会有用的。Swift简化了这些运算符的定制实现,并且精确地确定了你创建的每个类型的运算符所具有的行为。该CSS的十六进制颜色值#CC6699,在Swift中表示为0xCC6699。

  5. Swift学习:2.24 高级操作符

    不同于C语言中的数值计算,Swift的数值计算默认是不可溢出的。溢出行为会被捕获并报告为错误。在Swift中,你可以为你创建的所有类型定制运算符的操作。Swift支持如下所有C语言的位运算符:按位取反运算符按位取反运算符~对一个操作数的每一位都取反。负数的编码方式称为二进制补码表示。Swfit为整型计算提供了5个&符号开头的溢出运算符。

  6. js位运算在实际中使用的实例教程

    我们可能很少在编程中用位运算,如果没深入学习,可能也很难理解,下面这篇文章主要给大家介绍了关于js位运算在实际中使用的相关资料,需要的朋友可以参考下

  7. Java利用位运算实现加减乘除的方法详解

    我们经常使用的加减乘除,我们所看到的只是表面的效果,那么加减乘除在底层究竟是怎么实现的?今天就让我们一探究竟

  8. PHP 使用位运算实现四则运算的代码

    这篇文章主要介绍了PHP 使用位运算实现四则运算的代码,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

  9. 详解Python中位运算的简单实现

    位运算就是直接对整数在内存中对应的二进制位进行操作,一般是将数字化为二进制数后进行操作。本文将利用Python语言实现位运算,感兴趣的可以了解一下

  10. 详细聊聊React源码中的位运算技巧

    众所周知在React中,主要用到3种位运算符 —— 按位与、按位或、按位非,下面这篇文章主要给大家介绍了关于React源码中的位运算技巧的相关资料,需要的朋友可以参考下

随机推荐

  1. delphi – 主窗口按进程名称处理

    DelphiXe,Win7x64如何从进程名称(exe文件的完整路径)获取主窗口句柄,或至少一个类或窗口名称(如果该进程只有一个窗口).例:解决方法我同意Petesh的说法,你需要枚举顶级窗口并检查创建它的进程的模块文件名.为了帮助您开始枚举顶级窗口,这是一个delphi实现.首先,当你回调给你时,你需要一些与EnumWindows方法通信的方式.为此声明一条记录,该记录将保存您要查找的模块的文件

  2. 如何在Delphi中纯粹通过RTTI信息(即不使用任何实际对象实例)获取TObjectList的子项类型?

    我正在使用RTTI实现用于流式传输任意Delphi对象的通用代码,并且为了使其工作(更具体地说,为了使加载部分工作),我需要以某种方式获得TObjectList的子项类型<T>不使用任何实际对象实例的字段.要求不使用任何实际对象实例的明显原因是,在从流加载对象的情况下(仅基于要加载的对象的类类型的知识),我将不会有任何实例在加载完成之前完全可用–我宁愿只能访问相关类的纯RTTI数据.我希望能

  3. inno-setup – Inno Setup – 安装程序背景图片

    图像作为安装程序背景如何用inno5.5.9做到这一点?

  4. inno-setup – Inno Setup – 如何添加多个arc文件进行解压缩?

    使用InnoSetup解压缩弧文件.我希望有可能解压缩多个arc文件以从组件选择中安装文件(例如).但仍然显示所有提取的整体进度条.这可能吗?的回答的修改预备是相同的,参考其他答案.在ExtractArc中,为要提取的每个存档调用AddArchive.

  5. delphi – 如何在DataSet的帮助下在TAdvStringGrid中显示数据库中的BLOB图像

    解决方法CreateBlobStream正在创建一个TStream对象,而不是TMemoryStream.由于您不想将JPG写入数据库,因此应使用bmRead而不是bmReadWrite.我不习惯sqlite,但你必须确保使用合适的二进制日期类型.为了确保存储的图像真的是JPG,您应该编写JPG以进行测试,例如:

  6. inno-setup – 在Inno Setup的Code部分下载程序后运行程序

    如何运行我通过Internet下载的应用程序,在代码部分中使用,并等待该应用程序完成运行.我有,使用InnoTools下载程序,下载这两个文件,我想,在第二个完成下载后运行该下载,或jdk-8u111-windows-x64.exe,然后继续安装.解决方法使用其他下载插件,而不是ITD(请参阅下面的原因).例如,InnoDownloadPlugin.当您包含idp.iss时,它定义了一个全局IDP

  7. progress-bar – Inno Setup Run部分的简单进度页面

    我的安装程序非常简单,它基本上是:>欢迎页面>进展页面>最终页面欢迎页面和最终页面是标准页面.在Progress页面,我正在静默安装一堆其他程序.实际的脚本是在[Run]部分中安装每个程序.问题是酒吧达到100%然后停留在那里.我只能更改消息文本.我想要实现的是使用Pascal脚本显示进度,例如:这样我就可以显示更准确的进度条.这就是我所拥有的:问题是,当我构建安装程序时,它不显示欢迎页面.我做错了什么?

  8. delphi – 如何使“显示/隐藏桌面图标”设置生效?

    下面的代码调用SHGetSetSettings函数来隐藏桌面图标但它只是从视图菜单中取消选中“显示桌面图标”.我打电话给SHChangeNotify;更新桌面,但这不起作用?解决方法isa,要刷新桌面,您可以将F5键发送到progman窗口隐藏桌面图标的另一种方法是再次显示

  9. inno-setup – Inno Setup – 避免显示子安装程序的文件名

    我试图使用InnoSetup–Howtohidecertainfilenameswhileinstalling?(FilenameLabel)的想法Theonlysuresolutionistoavoidinstallingthefiles,youdonotwanttoshow,usingthe[Files]section.Installthemusingacodeinstead.UsetheEx

  10. inno-setup – Inno Setup磁力链接下载实施

    我目前正在使用InnoDownloadPlugin为我的安装程序下载文件,这个问题最大的问题是faila正确下载文件.因为连接不良等诸多原因.我想添加一种替代方法来下载文件,因此用户可以选择是否需要常规方式或torrent方式.我知道我可以使用aria2c.exe应用程序(https://aria2.github.io/),有人可以帮我实现它的inno设置代码吗?我需要的是使用torrent(ar

返回
顶部