- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
请耐心等待。
几个月前,我记得我的算法老师与我们讨论桶排序的实现(在我的算法书中称为分布排序)及其工作原理。基本上,我们不是按面值取数字,而是通过二进制表示开始比较,如下所示:
// 32 bit integers.
Input: 9 4
4: 00000000 00000000 00000000 00000110
9: 00000000 00000000 00000000 00001001
// Etc.
然后开始从右到左比较。
// First step.
4: 0
9: 1
Output: 9 4
// Second step
4: 1
9: 0
Output: 4 9 // Technically a stable algorithm, but we cannot observe that here.
// Third step
4: 1
9: 0
Output: 4 9
// Fourth step
4: 0
9: 1
Output: 9 4
就是这样;其他 28 次迭代都是零,因此输出不会再改变。现在,像这样比较一大堆字符串就可以了
// strings
Input: "Christian" "Denis"
Christian: C h r i s t i a n
Denis: D e n i s
// First step.
Christian: n
Denis: s
Output: Christian, Denis
// Second step
Christian: a
Denis: i
Output: Denis, Christian
// ...
等等。
我的问题是,比较带符号的字符(字节数字)是否比比较整数快?
如果我不得不假设,比较 1 字节的 char 比 4 字节的整数更快。它是否正确?我可以对 wchar_t 或 UTF-16/32 格式做出相同的假设吗?
最佳答案
在 C 或 C++ 中,char
只是一个单字节整数(尽管“一个字节”可能是也可能不是 8 位)。这意味着在典型情况下,您需要处理的唯一区别是单字节比较是否比多字节比较快。
至少在大多数情况下,答案是否定的。许多 RISC 处理器根本没有处理单个字节的指令,因此对单个字节的操作是通过将字节符号扩展为字、对字进行操作,然后(如有必要)屏蔽所有单个字节之外的位回零——即,对整个字进行操作通常可以是对单个字节进行操作的速度的三倍左右。
即使在像 x86 这样直接支持单字节操作的系统上,它们通常仍然较慢(在现代处理器上)。有几件事促成了这一点。首先,使用当前模式“自然”大小的寄存器的指令比使用其他大小的指令具有更简单的编码。其次,相当多的 x86 处理器具有所谓的“部分寄存器停顿”——尽管这都是隐式的,但它们在内部做一些类似于 RISC 的事情,对全尺寸寄存器执行操作,然后将其与原始值的其他字节。例如,如果您在 AL 中产生一个结果然后引用 EAX,那么与您在 EAX 中产生结果开始相比,该序列将花费更长的时间执行。
OTOH,如果您查看足够旧的处理器,则可能(而且经常)相反。举一个极端的例子,考虑一下 Intel 8080 或 Zilog Z80。两者都有一些 16 位指令,但通过 ALU 的路径只有 8 位宽——例如,一个 16 位加法实际上是作为两个连续的 8 位加法执行的。如果只用 8 位运算就可以了,速度大约是原来的两倍。尽管 8 位处理器在台式机上是一种(遥远的)内存,但它们仍在某些嵌入式应用程序中使用,因此这也并非完全过时。
关于c++ - 字母比较比数字比较慢吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4798262/
在 MySQL 数据库中,我在表中有一列既有纯数字也有混合数字/字母。没有模式,如果是纯数字我想区分,标记为true,否则为false。有什么好的方法可以使用吗?我试过: ID REGEXP '^[[
这个问题在这里已经有了答案: Numbers as column names of data frames (2 个回答) Why am I getting X. in my column names
尝试提出一个正则表达式来捕获诸如 AB1234 或 BA2321 之类的组。本质上需要捕获以 AB 或 BA 开头并后跟 4 位数字的任何内容。 目前,我有类似的东西,但这似乎没有考虑数字 (AB|B
var z = []; for(var i = 1; i len) z.push("a".repeat(len-i%len)) console.log(z.join("\n")); 关于jav
我需要一个仅用于数字、字母、空格和连字符的正则表达式。 像这样的 ^[a-zA-Z0-9]+$ 得到字母和数字,但我需要一个用于上述。这些真的很难理解! 最佳答案 这是你需要的: /^[0-9A-Za
有没有人可以帮助我解决 PDFBox 中的字母问题我正在尝试打印字母“ń”(波兰语字母)并且我得到了类似 þÿ J 的东西。 Dı B R O W 2S0 :K0 3I. 请帮忙! 最佳答案 我遇到了
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 5 年前。 Improve this ques
我尽量不让我的文本 block 把一个词分成几个部分并跳到下一行。对于每种设备尺寸,文本都会中断并造成可读性问题。我尝试将 marring-right 与 % 一起使用,但并没有太大帮助。 这是我的哈
这是我第一次向 Stack Overflow 发帖提问。我是编程新手,所以如果我说的奇怪或错误,请原谅。 在下面的文件中;它读取目录并将其保存到变量 nAddress 中。然后删除文件扩展名;将文件分
我希望当用户将鼠标悬停在页面上时,我的页面上的某些文本会重新排列字母。例如,将鼠标悬停在“WORK”上,它就会变成“OWKR”。我怀疑需要 js,但我对 js 还是很陌生。下面是我的 html:
我已经为此工作了几个小时,现在我有点卡住了....请帮助我。我是一个完全的编程障碍。除字母表方法外,所有方法都可以正常工作。 它将接收两个字符(大写或小写)并返回由给定 char 值范围组成的字符串。
我想编写一个程序,在输入的同一行中读取 n 个不同化学元素的名称(其中 1 ≤ n ≤ 17 和 n 也在输入中读取)(名称由空格分开)。化学元素的名称应存储在不同的字符串中以供进一步使用。 由于 n
我想隐藏一个字母,并在链接中显示另一个字母,当然,悬停字母的样式不同。例如: 这是一个... ...normal link. 这是一个... ...hovêrêd lînk. 如何实现?谢谢。 编辑:
我一直被这个相当愚蠢的想法所挑战。 所以我可以用 Blabla[span class=superI]i[/span]rest 替换所有出现的“i”:) 我的想法是在真正的 i“后面”添加一个额外的(红
本文以实例演示5种验证码,并介绍生成验证码的函数。PHP生成验证码的原理:通过GD库,生成一张带验证码的图片,并将验证码保存在Session中。 ?
下面给大家介绍下JS正则表达式 必须包含数字、字母、特殊字符 js正则表达式要求: 1. 必须包含数字、英文字母、特殊符号且大于等于8位 2. 特殊符号包括: ~!@#$%^&* 正
我在这里和网上四处寻找解决方案。 问题是我只想接受信件。但是,如果我至少输入一个字母,无论是否有符号或数字,它都会接受。如何获得仅 封信? if (!preg_match("/[a-zA-Z]/",
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 去年关闭。 Improve th
制表符分隔的文本文件,实际上是数据库表的导出(使用 bcp),具有以下形式(前 5 列): 102 1 01 e113c 3224.96 12 102 1 01 e185
我需要循环遍历数据数组并为每个数组值打印一个“递增”字母。我知道我可以做到这一点: $array = array(11, 33, 44, 98, 1, 3, 2, 9, 66, 21, 45); //
我是一名优秀的程序员,十分优秀!