分享一道360的C語(yǔ)言筆試題。x是一個(gè)行列均為1000的二維數(shù)組,下面代碼運(yùn)行效率最高的是哪個(gè)?
二維數(shù)組大家都很熟悉,正常人遍歷二維數(shù)組都是一行一行來(lái)的,為什么很少有人按列去遍歷?
這道筆試題其實(shí)考察的就是遍歷效率的問(wèn)題。
選項(xiàng)A,j是行,i是列,很顯然 x[i][j] 是按列訪問(wèn),先是第一列第一個(gè)元素,然后第一列第二個(gè)元素,以此類推。
選項(xiàng)B和選項(xiàng)C都存在按列訪問(wèn)。
只有選項(xiàng)D,屬于正常的按行遍歷。
那么問(wèn)題來(lái)了,為什么二維數(shù)組按行遍歷比按列遍歷來(lái)的快?
這個(gè)涉及的問(wèn)題就太多了,得從CPU高速緩存講起。
CPU處理速度很快,但是訪問(wèn)內(nèi)存太慢,嚴(yán)重影響了機(jī)器運(yùn)行效率。
于是就出現(xiàn)了高速緩存。
從名字應(yīng)該能看出,訪問(wèn)它速度確實(shí)快。
當(dāng)CPU發(fā)出內(nèi)存訪問(wèn)請(qǐng)求時(shí),會(huì)首先查看緩存內(nèi)是否有請(qǐng)求的數(shù)據(jù),如果有,直接返回,如果沒(méi)有,就要先把內(nèi)存中的數(shù)據(jù)載入緩存,再把它返回給處理器。
由于緩存比內(nèi)存貴很多,所以它的大小一般都以KB或者M(jìn)B為單位,如果是一級(jí)緩存,那就更小了。
題目中的二維數(shù)組大小接近4M,CPU在訪問(wèn)的時(shí)候,緩存先從內(nèi)存抓取數(shù)據(jù),而且一般都是抓取相鄰整個(gè)數(shù)據(jù)塊,簡(jiǎn)單點(diǎn)理解,就是當(dāng)前行以及后面的部分?jǐn)?shù)據(jù),這也符合內(nèi)存訪問(wèn)局部性特征。
如果二維數(shù)組按列遍歷,就需要不斷的抓取內(nèi)存的數(shù)據(jù),降低程序效率,這也將會(huì)失去緩存的意義。
審核編輯:劉清
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。
舉報(bào)投訴
原文標(biāo)題:為什么二維數(shù)組都是一行一行訪問(wèn)?
文章出處:【微信號(hào):學(xué)益得智能硬件,微信公眾號(hào):學(xué)益得智能硬件】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
相關(guān)推薦
來(lái)到這邊很久了,也從來(lái)沒(méi)自己發(fā)過(guò)帖。今天去面試,出了一個(gè)對(duì)二維數(shù)組按照某列進(jìn)行重新排序。小弟本來(lái)對(duì)數(shù)組這方面不是特別熟悉,想了半天結(jié)果沒(méi)做出
發(fā)表于 03-09 22:22
`怎么按列、行求得二維數(shù)組的均值啊`
發(fā)表于 09-06 12:45
程序?qū)崿F(xiàn)了把生成的一維數(shù)組更新二維數(shù)組各列功能。基本實(shí)現(xiàn)了LabVIEW二維
發(fā)表于 10-13 13:20
本帖最后由 ltoad 于 2015-12-9 23:11 編輯
輸入為一個(gè)二維數(shù)組A,列數(shù)不定要求以指定列進(jìn)行排序,比如指定第0列,
發(fā)表于 12-09 23:02
是按一維線性排列的。如何在一維存儲(chǔ)器中存放二維數(shù)組,可有兩種方式:一種是按行排列, 即放完一行之
發(fā)表于 07-12 08:55
Labview中對(duì)于一維數(shù)組可以直接排序,但如果是二維數(shù)組時(shí),特別是字符串類型二維數(shù)組,某一
發(fā)表于 09-30 16:06
怎么用C語(yǔ)言實(shí)現(xiàn)在二維數(shù)組里循環(huán)遍歷呢?
發(fā)表于 03-17 04:35
本文檔的主要內(nèi)容詳細(xì)介紹的是C語(yǔ)言程序設(shè)計(jì)教程之二維數(shù)組如何應(yīng)用二維數(shù)組的資料概述主要內(nèi)容包括了:1 了解二維
發(fā)表于 10-26 16:48
?3次下載
來(lái)自公眾號(hào):程序員小灰 第二天 什么意思呢?我們來(lái)舉個(gè)例子,給定下面這樣一個(gè)二維數(shù)組: 我們需要從左上角的元素1開(kāi)始,按照順時(shí)針進(jìn)行螺旋遍歷
發(fā)表于 11-26 14:01
?1801次閱讀
二維數(shù)組與數(shù)組指針以及指針數(shù)組
發(fā)表于 08-16 09:02
?2746次閱讀
定義一個(gè)兩行三列的二維數(shù)組,總共有6個(gè)元素
發(fā)表于 09-11 14:51
?957次閱讀
用二維數(shù)組存儲(chǔ)最小元素是怎么實(shí)現(xiàn)的?? 在計(jì)算機(jī)編程中,數(shù)組是一種非常重要的數(shù)據(jù)結(jié)構(gòu)之一。它用于存儲(chǔ)一系列相同類型的變量,這些變量被放入單一的數(shù)組中并通過(guò)一個(gè)唯一的編號(hào)(稱為
發(fā)表于 09-13 11:17
?568次閱讀
它們的優(yōu)缺點(diǎn)和一些常見(jiàn)的操作。 使用嵌套列表創(chuàng)建二維數(shù)組: 嵌套列表是Python中創(chuàng)建二維數(shù)組最簡(jiǎn)單和最基本的方法之一。每個(gè)內(nèi)部的列表都代表了一行或者一
發(fā)表于 11-21 15:10
?3852次閱讀
在Python中,可以通過(guò)使用列表嵌套的方式來(lái)定義二維空數(shù)組。具體步驟如下: Step 1: 創(chuàng)建一個(gè)空的二維列表 要?jiǎng)?chuàng)建一個(gè)空的二維數(shù)組,
發(fā)表于 11-21 15:12
?1867次閱讀
過(guò)程。接下來(lái),我將為你詳盡、詳實(shí)、細(xì)致地介紹四種常用的方法。 方法一:使用列表推導(dǎo)式(List Comprehension) 這是一種簡(jiǎn)單而又優(yōu)雅的方法,可以快速將一維數(shù)組轉(zhuǎn)換為二維數(shù)組
發(fā)表于 11-23 14:54
?5560次閱讀
評(píng)論