为什么在C ++程序中处理排序数组比未排序数组更快?
在C++中,由于分支预测,处理排序数组要比未排序数组快。在计算机体系结构中,分支预测确定程序指令流中的条件分支(跳转)是否可能被采用。
让我们举个例子:
if(arr[i] > 50) {
Do some operation B
} else {
Do some operation A
}如果我们按以下未排序和已排序的顺序为100个元素运行此代码,则会发生以下情况:
对于排序数组:
1,2,3,4,5,……50,51………100 A,A,A,A,A A,B B It will load the correct branch in pipeline and correct sequence A,A,A, A,A,A,A,A A,B B
对于未排序的数组:
5,51,6,90,4,49,60… A,B,A,B,A,A,A,B
分支预测在这里没有发挥重要作用。很难预测A和B之间的正确操作。
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志